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本 书 讲 的 不 是 你 写 的 代码 ， 而 是 你 赖 以 生 
存 的 密码 。 


软件 开发 行业 的 从 业 人 员 成 千 上 万 ， 你 如 
何 保证 自己 出 色 地 完成 工作 ? 这 本 书 里 没有 浮 
夸 的 老生 常 谈 ， 作 者 汇集 十 余年 来 的 软件 开发 
经 验 ， 从 各 个 角度 审视 这 一 行业 ， 探 讨 了 保持 
健康 工作 状态 需要 怎么 去 做 。 


如 何在 最 漫长 的 项 目 中 保持 效率 ， 如 何 建 
立 一 个 适合 自己 而 不 是 牵 绊 自己 的 工作 流程 ， 
如 何 面 对 目标 和 你 不 一 致 的 客户 …… AR Ltt 
中 遇 到 的 许多 问题 ， 都 出 现在 作者 的 笔 端 。 有 
些 问题 如 果 处 理 得 不 好 ， 哪 怕 是 最 有 经 验 、 最 
有 干劲 的 程序 员 也 可 能 被 击 垮 。 但 有 了 正确 的 
手段 ， 你 就 可 以 克服 这 些 难 题 ， 成 为 你 梦想 中 
的 专业 程序 员 。 

在 这 五 十 多 篇 智慧 小 文中 ， 你 还 会 学 到 ; 

o 为 什么 软件 行业 中 针对 流程 和 开发 职务 
的 很 多 传统 方法 都 是 错 的 ， 以 及 如 何 发 现 这 些 
错误 ; 

© 为 什么 你 必须 对 消闲 项 目 和 没有 期 限 的 
项 目 说 不 ; 

o 如 何 把 代码 生成 融入 你 的 开发 流程 ， 以 
及 它 有 什么 你 想不到 的 好 处 ; 

o 客户 和 最 终 用 户 不 同意 你 选择 的 方法 时 
怎么 办 ; 

o 如 何 言传 身 教 ， 将 知识 传授 给 下 一 代 程 
序 员 。 


如 果 你 准备 长 期 从 事 软 件 开 发 行业 ， 相 信 
你 会 不 断 地 反复 阅读 这 本 书 的 。 
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Ka Wai Cheung 

中 文 名 张 家 为 ， 是 程序 员 、 设 计 师 ， 还 是 
芝加哥 We Are Mammoth ( 我 们 是 猛 独 ) 
公司 的 联合 创始 人 。 为 各 行 各 业 的 客户 制 
作 应 用 软件 ， 也 制作 自 有 的 一 些 基 于 网 页 
的 软件 。 


劳 佳 

上 海 交通 大 学 电子 工程 系 硕士 ,现在 SAP 
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分 校 人 文 建筑 之 旅 》 等 书 。 
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内 容 提 要 


本 书 集合 了 作者 在 软件 行业 里 总 结 的 第 一 手 教训 、 体 会 和 走 过 的 弯路 。 话 题 涉 
及 程序 员 生 活 的 方方面面 ， 例 如 ， 如 何 保 持 开 发 动力 ， 如 何 提 高 生产 力 ， 如 何 摆 脱 
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员 的 自豪 感 等 。 每 个 话题 独立 成 篇 、 言 简 意 赎 ， 引 人 思考 。 

本 书 不 仅 适合 编程 老手 阅读 ， 也 适合 编程 菜 岛 学习， 还 适合 想 了 解 软件 这 个 行 
业 的 人 士 阅读 。 
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Copyright © 2012 The Pragmatic Programmers, LLC. Original English 
language edition, entitled The Developer’s Code: What Real Programmers Do. 
Simplified Chinese-language edition copyright © 2012 by Posts & 


Telecom Press. All rights reserved. 


本 书 中 文 简体 字 版 由 The Pragmatic Programmers, LLC. 授 权 人 民 
邮电 出 版 社 独家 出 版 。 未 经 出 版 者 书面 许可 , 不 得 以 任何 方式 复制 或 
抄袭 本 书 内 容 。 

版 权 所 有 ， 侵 权 必 究 。 
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“这 是 Pragmatic Programmers 系列 中 的 又 一 本 书 一 一 对 新 手 来 说 
是 指引 ， 对 专家 来 说 是 重 温 ， 这 是 关于 程序 员 技 艺 ( 和 生活 ) 的 一 本 
美妙 的 智慧 集 。 


Derek Sivers, CD Baby 和 sivers.org 的 创始 人 

“Ka Wai Cheung 先生 为 那些 寻找 自己 赖 以 生存 的 代码 的 专业 开 
发 人 员 写 了 一 本 书 。 这 本 书 不 是 用 那些 在 任何 博客 中 都 能 找到 的 传统 
想法 拼凑 起 来 的 ， 而 是 用 强 有 力 且 有 针对 性 的 方法 , 讲述 专业 编程 的 
技艺 和 现实 。 

如 果 你 想 找 一 本 新 瓶装 旧 酒 的 编程 规则 ， 那 就 不 用 看 这 本 书 了 。 
但 是 ,， 如 果 你 正在 寻找 一 种 视角 ,看 看 软件 开发 是 什么 , 或 者 你 想 要 
一 套 由 真实 经 验 提炼 出 的 指导 方针 ， 那 这 本 书 正 是 你 需要 的 。” 

Bob Walsh， 作 家 、47 Hats 的 创始 人 

“充满 “美味 ”的 经 验 ， 每 篇 的 大 小 也 十 分 “适口 ”一 一 在 这 本 
书 里 你 可 以 学 到 很 多 。 花 上 些 时 间 从 过 来 人 那里 学 学 吧 。” 

一 一 Adam Hoffman, 高 级 开发 主管 

“一 本 好 书 ， 有 现代 程序 员 从 日 新 月 异 的 世界 中 得 到 的 提示 、 技 
巧 和 经 验 教训 。 从 事 开发 或 与 开发 人 员 合作 的 人 士 不 可 不 看 。 
Caspar Dunant, Webfish 
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详 者 J 


这 本 小 书 名 叫 《 卓 越 程 序 员 密码 》 但 大 部 分 内 容 讲 的 不 是 具体 
的 技术 。 书 中 的 话题 涉及 程序 员 生 活 的 方方面面 , 每 个 话题 独立 成 篇 、 
AAR, BERZAIZ, SABZ. SUA H FEIE, Eis 
不 断 ， 如 何 保 证 工作 效率 ?有 些 程序 员 朋 友 ， 自身 水 平 很 高 ,为 何 疝 
别人 讲解 问题 时 却 效果 不 佳 ?” 如何 和 不 断 提要 求 的 客户 周旋 ?作者 
在 行业 中 浸 淫 多 年 ， 在 团队 建设 、 项 目 管理 等 方面 都 有 独到 的 见解 。 
当然 ， 书 中 更 少不了 关于 软件 开发 本 身 的 技巧 ， 复 杂 性 管理 、 重 构 、 
代码 生成 等 都 是 对 实际 工作 很 有 指导 意义 的 方法 。 

如 果 你 从 事 开 发 ,在 上 班 的 路 上 读 上 一 两 篇 , 也许 书 中 的 观点 就 
能 给 一 天 的 工作 带 来 一 点 灵感 。 即 使 你 从 来 不 写 程 序 , 读 读 这 本 书 也 
有 助 于 了 解 一 下 这 个 热门 而 有 趣 的 行业 。 要 是 你 的 男 朋 友 刚 好 是 个 程 
序 员 , 这 本 书 或 许 能 让 你 更 好 地 走 近 他 的 生活 , 理解 他 的 种 种 行为 也 
说 不 定 呢 。 

原文 笔触 轻快 ， 语 言 流畅 ， 读 来 丝毫 没有 读 技术 文献 的 枯燥 感 。 
作为 译 者 , 我 也 希望 尽 可 能 带 给 读者 同样 轻松 愉快 的 阅读 体验 。 限 于 
水 平和 精力 ,译文 不 妥 之 处 , 还 望 读者 指正 。 图 灵 岳 新 欣 编辑 和 武 卫 
东 总 编 为 译 稿 润色 付出 了 辛勤 的 劳动 ， 在 此 特别 致谢 。 

最 后 值得 一 提 的 是 , 本 书 的 翻译 和 编辑 工作 均 在 图 灵 社 区 上 在 线 
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完成 。 文 本 使 用 Markdown 语言 描述 ， 实 时 更 新 ， 互 动 编辑 ， 并 逐 章 
发 布 电子 版 。 这 种 新 的 出 版 模式 ， 消 除了 译 者 和 编辑 之 间 反 复发 稿 的 
烦琐 ,也 让 读者 能 够 随时 追 上 最 新 的 章节 。 在 如 今 敏捷 出 版 和 移动 阅 
读 的 大 潮 中 ， 这 一 尝试 显得 尤为 合宜 ， 十 分 可 嘉 。 


FAE 
2012 8 A 
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中 文 版 序 


亲爱 的 读者 : 

在 编程 的 世界 里 ,我们 会 和 各 种 各 样 的 “语言 ”打交道 。 虽然 我 
主要 的 服务 器 端 开 发 语言 是 C#， 但 我 的 工作 方法 却 几 乎 可 以 完全 应 
用 到 Java, PHP, Ruby 或 Python 上 。 编 程 语言 虽 有 不 同 ， 核 心 的 编 
程 思想 、 方 法 和 架构 却 是 高 度 类 似 的 。 我 们 只 是 用 不 同 的 方式 来 表达 
而 已 。 

我 们 的 工作 方式 也 具有 普遍 性 一 一 如 何 保持 干劲 、 提 高 成 效 , 教 
学 的 重要 性 ， 如 何 与 客户 合作 ,如何 发 现 合适 的 流程 ， 勇 于 摆脱 不 好 
的 流程 。 此 外 ,我 猜想 ,我 通过 编程 学 到 的 人 生 一 课 , 不 仅 适 合 在 美 
国 工作 的 我 们 ， 也 可 能 适用 于 在 中 国 工 作 的 你 。 

作为 在 美国 出 生 的 第 一 代 华 裔 , 我 非常 荣幸 这 本 书 能 够 被 翻译 成 
我 父辈 的 语言 。 我 在 美国 长 大 , 在 西方 文化 中 生活 ， 同 时 也 有 一 些 中 
的 传统 价值 观 。 我 对 于 应 该 如 何在 这 个 行业 工作 的 看 法 肯定 受到 了 
两 种 文化 的 影响 。 

无 论 你 是 刚刚 投身 编程 事业 ， 正 在 创业 , 还 是 在 寻找 一 些 新 鲜 的 
观点 ， 我 都 希望 这 本 书 在 现在 和 未 来 都 能 对 你 有 所 启发 。 


RRA 
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Dear readers, 

In the world of programming, we work with “languages” of all 
different kinds. Though my primary server-side development language is 
C#, the way I work almost fully translates to the world of Java, PHP, Ruby, 
or Python. Core programming ideas, methodologies, and architectures are 
highly similar between these different coding worlds. We just express them 
in different ways. 

The same is true for how we work - How we stay motivated and 
productive, the importance of teaching, working with clients, discovering 
the processes that work just-right and being brave enough to shed the ones 
that don’t. And, I’'d imagine that the life lessons I’ve learned through 
programming translate not just to how we work in the U.S., but how you 
might work in China. 

As a first-generation American born to Chinese parents, I was 
tremendously humbled to have this book translated to my ancestral 
language. I grew up in the United States, living in a western culture while 
growing up with some traditional Chinese values. My opinions on how we 
ought to work in this industry have certainly been influenced by both 
cultures. 

Whether your just beginning your career in programming, starting 
your own small business, or seeking some fresh perspectives, I do hope 


you find this book valuable now and in the future. 


Sincerely, Ka Wai Cheung 
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致谢 


2010 年 秋 , 这 本 书 的 初稿 差不多 已 经 写 好 了 , 于 是 我 开始 向 儿 家 
技术 出 版 社 投稿 。 虽然 有 些 反 馈 还 不 错 , 但 一 直 没 有 人 答应 出 版 。 多 
数 出 版 社 的 意见 主要 有 两 条 : 一 是 这 类 书 一 般 不 好 卖 ， 二 是 我 需要 再 
加 上 更 多 的 后 续 内 容 才 值得 出 版 。 

Andy Hunt 和 Dave Thomas 看 问题 的 角度 与 众 不 同 。 因 此 ， 首 先 
我 想 感谢 Andy 和 Dave, 他 们 和 我 一 样 ， 相信 这 本 书 在 我 们 这 个 行业 
会 有 一 席 之 地 。 本 书 能 够 某 列 Pragmatic Bookshelf 这 套 出 色 的 从 书 之 
F, FREI AS PEARSE 

像 这 样 一 本 书 迫 切 需要 一 位 好 编辑 能 够 客观 地 评价 它 , 并 在 
作者 被 盘根错节 的 细节 柑 绊 的 时 候 ， 能够 从 高 处 俯 览 全 局 。 我 要 感谢 
Brian P. Hogan 在 整个 过 程 中 的 出 色 工 作 。 无 论 是 从 内 容 还 是 叙述 方 
式 而 言 ， 这 本 书 胜 过 初稿 之 处 都 不 可 以 道里 计 。 

我 要 特别 感谢 Andertoons.com 的 Mark Anderson。 他 富有 创意 的 
漫画 和 机 智 遍布 全 书 ， 平 添 了 几 分 幽默 ， 让 本 书 大 为 增色 。 

感谢 Derek Sivers 、Bob Walsh, Caspar Dunant, Colin Yates, Juho 
Vepsäläinen, Steve Cholerton 和 Kim Shrier 抽 出 时 间 ， 热 心 仔细 审读 
每 一 个 章节 。 


这 本 书 的 灵感 大 部 分 来 自 于 我 在 We Are Mammoth 的 经 验 ， 这 是 
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2 致 ” 谢 

我 和 Craig Byrant 在 2006 年 创立 的 Web 开发 工作 室 。 在 过 去 的 五 年 
E, 我 们 不 断 挑 战 自己 , 思索 我 们 对 答 工 作 的 方式 ， 并 彼此 坦 陈 我 们 
的 意见 。 感 谢 我 的 团队 
Anthony、Jennifer、Grant 和 Lindsay， 你 们 每 天 都 带 给 我 新 的 经 验 和 
教训 。 


Craig, Michael, Mustafa, Tom, Sam, 
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第 1 章 


引 二 


我 被 代码 通 饮 过 一 一 两 次 。 

第 一 次 ， 是 我 在 大 学 一 年 级 上 的 一 门 编程 课 。 这 是 一 门 必修 课 ， 
我 就 选 了 。 结 果 这 和 我 小 时 候 看 过 无 数 次 的 电影 场景 完全 是 两 码 事 。 
我 并 没有 敲 上 几 个 简单 命令 , 按 下 回 车 ， 然 后 就 看 到 一 个 垃圾 桶 样 的 
Blas AAR “PREF” o 
课 尝 上 甚至 连 个 垃圾 桶 机 器 人 都 没有 ， 而 全 是 一 堆 什么 指针 啊 ， 
内 存 分 配 啊 , 对 象 实例 化 之 类 的 。 我 为 了 弄 清 楚 这 都 是 些 什么 玩意 儿 
搞 得 焦头烂额 ,不 过 ,有 一 件 事 是 明摆着 了 一 一 我 根本 不 是 编程 的 料 。 

我 想 成 为 一 个 艺术 家 , 或 者 当 个 数学 家 。 我 想 要 有 创造 力 还 要 能 
够 精确 一 一 就 像 和 人们 说 的 ， 左 脑 右 脑 一 起 上 。 编程 似乎 太 偏向 左 半球 
了 ,可 是 我 也 想 不 出 什么 其 他 的 职业 道路 , 同时 能 够 在 两 个 世界 施展 。 

短 短 几 年 后 , 互联 网 的 大 潮 彻 底 改 变 了 编程 的 景象 。 编 程 突 然 就 
变 得 那么 实际 ,那么 触手 可 及 ， 而 且 还 和 设计 关系 紧密 。 艺 术 和 逻辑 
几乎 被 看 做 同样 重要 。 第 一 次 ,我 真 的 觉得 能 够 享受 这 份 工作 ， 可 以 
把 我 对 于 创造 力 和 逻辑 的 热情 都 倾注 到 网 络 应 用 上 。 所 以 , 虽然 心怀 
SD, RERE T o 

讲 句 老实 话 , 我 回来 完全 是 男 有 原因 。 在 之 前 的 两 年 里 , 我 学 习 
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2 81 5| 言 
了 其 他 很 多 学 科 , 都 似乎 有 太 多 太 多 的 未 解 之 这 。 是 去 构思 粒子 物理 
里 的 大 统一 理论 , 还 是 去 找 最 大 的 素数 ? 毫 无 疑问 , 这 些 任 务 简 直 难 
到 无 法 想象 ,让 人 望 而 生 县 。 我 实在 干 不 了 这 个 。 还 有 , 那个 讲 存在 
主义 的 课 也 没 能 把 事情 说 清楚 。 我 是 个 年 轻 人 ,我 想 要 的 是 答案 ， 而 
不 是 越 来 越 多 的 问题 。 

编程 。 我 曾经 唯 忍 避 之 不 及 的 那个 科目 ， 现 在 成 了 我 的 避风 港 。 
不 管 怎么 说 , 计算 机 科学 还 是 人 摘出 来 的 。 所 有 的 事情 肯定 都 有 个 答 
案 。 我 期 待 的 职业 生涯 , 应 该 能 让 我 这 种 寻求 答案 的 人 大 展 宏图 一 一 
你 能 把 甘 醇 的 代码 变 成 顾客 、 同 事 和 客户 常 在 的 笑脸 。 规则 都 已 经 定 
好 了 ,我 们 只 要 做 就 是 了 。 困 难 无 非 就 是 在 代码 里 面 而 已 , 我 当时 是 
这 么 想 的 。 

我 第 二 次 来 做 编程 , 才 发 现 又 上 当 了 一 一 显然 ,实际 远 不 是 这 么 
回 事 。 


1.1 EE 21 世纪 的 程序 员 


就 像 我 在 接 下 来 的 十 五 年 中 发 现 的 那样 ,隐士 不 适合 搞 编程 。 什 
么 有 个 超级 技术 狂 ， 典 在 幽暗 的 地 下 室 里 , 挥汗如雨 几 个 月 , 然后 拿 
出 最 终 产 品 ， 石 破 天 惊 ， 尽 享 荣华 。 绝 对 不 是 这 么 回 事 。 

现在 ,应 用 程序 是 主流 。 即 我 们 为 每 一 位 用 户 做 的 那 种 。 客 户 可 
能 了 解 我 们 如 何 工 作 , 也 可 能 完全 没什么 概念 。 我 们 的 交付 周期 有 时 
修 是 按照 白 驹 过 际 的 星期 来 算 的 , 而 不 是 按照 月 或 者 年 算 的 。 人 可 能 
突然 一 下 子 就 觉得 疲惫 不 堪 ， 而 拖延 可 能 是 最 容易 走 的 那 条 路 。 对 于 
我 们 一 一 当今 的 开发 人 员 来 说 , 软件 生产 中 所 涉及 的 障碍 已 经 远 远 超 
出 了 开发 环境 。 

我 有 个 好 朋友 经 常 和 我 开玩笑 。“ 你 工作 的 时 候 到 底 都 干 了 些 
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1.2 吸取 第 一 手 教 训 3 

IE? “她 知道 我 是 个 程序 员 , 但 并 不 是 很 确定 程序 员 具 体 都 做 些 什么 。 
她 问 我 问题 时 的 那 种 刻薄 质问 的 口气 ， 就 像 《 上 班 一 条 虫 》" 里 的 那 
个 办 公 室 顾问 Bob Slydell 一 样 。 

我 是 这 么 和 她 说 的 : 我 是 一 个 无 认证 但 是 超级 有 逻辑 的 心理 学 
家 、 理 疗 师 、 机 械 工 、 外 交 官 、 商 人 和 教师 ,我 所 在 的 行业 ,迄今 仍 
然 每 时 每 天 都 有 着 新 的 诠释 。 

这 就 是 我 对 当今 的 程序 员 能 够 给 出 的 最 简洁 的 定义 了 。 


1.2 吸取 第 一 手 教训 


我 叫 张 家 为 。 我 是 个 程序 员 、 设 计 师 ， 还 是 芝加哥 We Are 
Mammoth” ( 我 们 是 猛 独 ) 公司 的 创始 合伙 人 。 我 们 为 各 行 各 业 的 客 
户 制作 应 用 软件 ,也 制作 我 们 自 有 的 一 些 基 于 网 页 的 软件 。 后 面 会 再 
谈 到 这 一 点 。 

这 本 书 集合 了 我 自己 在 行业 里 总 结 的 第 一 手 的 教训 、 体 会 和 走 过 
的 弯路 。 对 于 编程 老手 来 说 ,你 可 能 会 发 现 我 写 的 某 些 轶 事 自 己 也 经 
历 过 。 我 们 可 以 一 起 大 笑 、 欢 呼 或 是 流泪 。 对 于 刚刚 开始 征程 的 菜鸟 
来 说 , 希望 这 本 书 能 够 为 你 进入 行业 的 头 几 年 助 上 一 辟 之 力 。 

过 去 十 五 年 中 , 我 得 到 的 教训 数不胜数 。 下 面 仅 举 几 个 这 本 书 里 
谈 到 的 话题 。 

口 为 什么 软件 行业 中 许多 传统 的 开发 流程 和 职责 分 配 已 经 过 时 
了 ， 以 及 如 何 找 出 这 些 问 题 。 
口 为 什么 要 对 消闲 项 目 说 “不 ”， 为 什么 开放 的 时 间 表 对 生产 力 


D 《上 班 一 条 虫 》( Office Space ) 是 1999 年 出 品 的 一 部 美国 电影 。 译 者 注 
D 我 们 的 网 站 是 http://www.wearemammoth.com ,我 们 的 博客 网 址 是 http://blog. weare- 


mammoth.com。 
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4 #12 引 5 

至 关 重 要 。 

O 协作 的 工作 环境 如 何 大 幅 提高 我 们 的 效率 , 又 如 何 大 大 降低 我 

们 的 效率 。 

口 如 何 让 代码 生成 成 为 开发 流程 中 自然 而 然 的 一 部 分 , 以 及 它 除 

了 让 生成 代码 更 快 还 有 什么 好 处 。 

口 如 何 更 好 地 与 不 能 面对面 交流 的 客户 打交道 , 以 及 如 何 面 对 不 

管 软件 做 了 什么 新 改动 都 会 大 发 雷霆 的 客户 。 

O 为 什么 大 幅 加 薪 和 “员工 是 我 们 最 宝贵 的 财富 ”这 人 句 古老 的 口 

号 并 不 意味 着 更 好 的 技术 工作 。 

口 如 何 认识 到 软件 本 身 已 经 太 过 复杂 了 。 

口 如 何 成 为 更 好 的 老师 , 让 我 们 能 够 把 知识 在 程序 员 中 一 代 代 传 
下 去 。 


13 ”这 本 书写 的 是 我 们 自己 


这 本 书 是 写 给 各 种 各 样 的 程序 员 的 。 不 过 , 它 和 代码 本 身 关 系 不 
大 。 不 管 你 用 的 是 C#, Ruby, Python, PHP, Java, JavaScript 抑或 
是 ActionScript， 都 没什么 要 紧 的 。 也 无 论 你 是 在 搞 数 据 库 ， 写 服务 
器 端 代码 ， 还 是 做 界面 脚本 ,都 无 所 谓 。 这 本 书 讲 的 是 在 标识 符 和 对 
象 这 个 层面 之 外 ， 专 业 程序 员 的 方方面面 。 

这 倒 也 不 是 说 我 们 就 把 编程 弃 之 一 旁 , 会 有 些 地 方 谈 到 代码 。 不 
过 ,在 谈 到 代码 的 时 候 , 我 们 会 用 一 种 不 那么 技术 化 的 全 局 眼光 来 看 。 
我 们 不 会 一 下 子 给 你 列 出 一 堆 什么 最 佳 实践 或 者 设计 模式 之 类 的 。 这 
些 东西 有 很 多 别 的 书 都 讲 得 很 好 了 ， 我 们 只 会 适时 提 到 一 些 。 

这 本 书 讲 的 是 真正 的 、 现 代 的 程序 员 是 怎样 让 我 们 的 行业 欣欣 向 
荣 的 。 我 们 开始 吧 。 
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FRA. 设计 师 设计 。 但 这 具体 是 什么 意思 呢 ? 还 没有 什么 

电视 真人 秀 节 目 或 者 好 莱 坞 电影 展示 过 我 们 到 底 是 如 何 工作 的 。 先 别 
CERK 你 可 能 想到 了 电影 《社交 网 络 》( The Social Network ), 
但 它 对 这 个 行业 的 A 生 。 所 以 , 要 是 有 人 问 我 是 干 什 
么 的 , 我 常常 要 打 些 比方 。 这 个 行业 充满 了 比喻 , 我 们 用 比喻 来 向 行 
外 人 描述 自己 的 工作 。 

大 厨 用 不 着 琢磨 亮 饪 要 怎么 比喻 , 肉 汤 要 是 太 咸 了 ,你 一 下 就 能 
尝 出 来 了 ; 音乐 家 也 不 用 这 么 抛 弯 抹 角 地 描述 歌曲 , 一 个 调子 听 起 来 
太 老 套 ， 是 因为 你 早先 就 听 过 一 样 的 节奏 。 别 人 一 下 就 明白 了 。 这 些 工 
作 都 属于 不 用 解释 就 很 清楚 的 。 管 道 安 装 工 和 砌 砖 工 之 类 的 工作 更 是 不 
言 自 明了 。 

然而 ,编程 可 不 大 一 样 。 普 通 人 看 不 出 来 什么 样 的 代码 优雅 ， 什 
么 样 的 代码 一 团 糟 。 还 有 ， 我 们 这 个 行业 非常 新 。 人 类 做 饭 、 创 作 音 
乐 、 盖 房子 都 有 几 千 年 了 ,可 是 考古 学 家 还 没 在 岩 壁 上 发 现 “ 人 类 坐 
ERAT” PAI. 
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6 $25 kb 喻 
所 以 ， 我们 必须 用 比喻 作为 “元 语言 ””。 这 不 仅 让 我 们 能 够 把 
编程 的 独特 性 讲述 给 普罗 大 众 , 而 且 还 经 常 是 我 们 解决 软件 问题 时 的 


= 


@ 在 语言 学 上 ， 元 语言 是 指 用 来 谈论 、 观 察 和 分 析 另 一 种 语言 【对象 语言 ) 的 语言 。 
它 可 以 是 自然 语言 ， 如 学 习 外 语 时 用 于 解释 外 文 的 本 民族 语言 ， 也 可 以 是 一 套 语 
言 符 号 。 一 译 者 注 
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第 1 篇 ”谨慎 使 用 比喻 7 


第 1 篇 ”谨慎 使 用 比喻 


这 就 是 危险 的 地 方 。 要 当心 ! 

有 时 候 ， 比 喻 和 现实 之 间 的 界限 可 能 会 模糊 。 比 喻 可 能 让 我 们 过 
于 重视 那些 不 重要 的 东西 ， 而 对 真正 重要 的 掉以轻心 。 

如 果 太 投入 这 些 比喻 里 面 , 我 们 可 能 做 不 出 最 好 的 决定 。 比 喻 会 
像 恶 魔 一 样 庶 住 我 们 的 双眼 ,让 我 们 看 不 见 事实 。 所 做 的 决定 可 能 在 
比喻 的 语 境 下 非常 有 道理 , 但 抽 丝 剥 草 到 了 制作 应 用 软件 这 个 实际 业 
FE, 我 们 很 容易 就 被 带 仿 了。 我们 有 时 候 过 于 依赖 在 比喻 上 看 到 的 
好 处 ， 却 没有 注意 到 现实 的 情况 。 

比如 , 我 们 常常 用 传统 的 建筑 行业 来 比喻 建造 软件 的 过 程 ， 毕竟 
很 多 职务 头衔 都 是 从 这 个 比喻 中 来 的 。 于 是 我 们 给 自己 取 了 软件 架构 
师 、 信 息 架 构 师 、 高 级 程序 员 、 初级 程序 员 以 及 项 目 经 理 之 类 的 名 字 ， 
很 多 人 还 把 线 框图 、 说 明 书 、 流 程 图 、 甘 特 图 、 瀑 布 开发 模型 之 类 奉 
KER 软件 开发 流程 中 很 大 一 部 分 都 是 跟 在 其 他 行业 屁股 后 面 摘出 
来 的 。 

虽然 这 些 概念 在 其 他 行业 中 很 重要 , 对 我 们 的 行业 也 有 那么 一 些 
好 处 , 但 它们 也 很 容易 束 住 我 们 的 手脚 。 如 果 停 下 来 想 想 为 什么 一 定 
要 用 某 种 特定 的 方式 来 解决 一 个 问题 , 也 许 就 能 追根 溯源 ， 发现 我 们 
对 传统 建筑 行业 这 个 比喻 ( 或 其 他 菏 个 比喻 ) 跟 得 太 紧 了 。 

那么 ， 比 喻 给 我 们 造成 了 哪些 伤害 呢 ?” 先 来 看 几 个 例子 , 我们 把 
实际 建筑 行业 中 的 概念 硬 拉 到 软件 上 来 ， 却 发 现 不 怎么 合适 。 
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在 传统 建筑 行业 中 , 规划 是 至 关 重 要 的 。 有 些 东西 就 是 必须 比 另 
外 一 些 东 西 先 做 , 这 没什么 好 争辩 的 。 打 好 壁 骨 框架 才能 铺 上 下 水 管 
道 , 铺 好 了 管道 才能 装 墙 面 ,， 墙 面 装 上 了 才能 粉刷 。 要 是 建 个 摩天 大 
楼 ， 撤 销 、 剪 切 或 者 复原 显然 是 行 不 通 的 。 

软件 的 撤销 就 是 CTRL+Z, 软件 的 剪 切 就 是 CTRL+X, 软件 的 复 
原 就 是 源码 控制 里 面 的 代码 回 深 。 


“这 儿 可 没有 Ctrl-X， 剪 刀 就 是 干 这 个 用 的 。 


建筑 上 没 法 享受 这 些 简洁 而 强劲 的 按键 , 所 以 需要 非常 详尽 的 说 
明 书 。 日 进 斗 金 的 房地产 生意 和 灾难 性 的 头条 新 闻 之 间 就 只 有 一 步 
之 遥 。 

假设 我 们 是 传统 的 建筑 师 , 拥有 软件 开发 的 各 种 快捷 方式 , 那么 
这 世界 真是 太美 好 了 。 原材料 取 之 不 尽 。 我们 可 以 几 个 星期 就 搞定 一 
个 实际 大 小 的 建筑 模型 , 还 可 以 对 悬索桥 反复 做 压力 测试 。 要 是 桥 断 
了 ， 谁 在 乎 呢 ?” 几 分 钟 就 可 以 复制 出 十 座 新 桥 来 ! 
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当然 了 ， 这 些 不 过 是 白 日 做 梦 罢 了 。 所 以 , 要 是 打算 建造 一 栋 摩 
天 大 楼 ， 把 建筑 说 明 写 得 详细 到 让 人 想 吐 才 是 最 合理 的 做 法 。 

IR, 这 些 就 是 我 们 这 个 行业 独 有 的 奢华 享受 了 。 软 件 组 件 又 
不 需要 等 着 本 地 的 工厂 发 运 字母 和 数字 。 打 字 、 编 译 、 测 试 ， 然 后 重 
复 就 行 了 。 我 们 可 以 在 实际 产品 上 测试 代码 ， 而 不 用 对 着 产品 的 某 种 
模型 测试 。 在 开发 过 程 中 , 我 们 可 以 看 着 悬索桥 断 上 千 百 次 , 在 各 种 
地 方 断 ， 在 各 种 条 件 下 断 ， 而 不 用 担心 浪费 材料 或 者 闹 出 人 命 。 这么 
做 完全 是 可 行 的 。 完 成 软件 之 后 ， 同 样 的 程序 可 以 被 复制 1000 次 ， 
不 费 吹 灰 之 力 。 

拉 斯 韦 加 斯 的 Wynn 大 酒店 的 开发 商 在 2008 年 又 建 了 一 个 几乎 
一 模 一 样 的 酒店 , 叫做 Encore。 他 们 可 没 法 简单 地 把 前 一 个 作品 复制 
粘贴 到 旁边 的 空地 上 。 他 们 还 得 从 头 开始 设计 、 规 划 ， 只 是 为 了 建 一 
个 几乎 一 模 一 样 的 建筑 。 

在 软件 还 需要 用 磁盘 承载 代码 的 年 代 , 进行 完备 的 规划 还 比较 有 
意义 。 然 而 ， 基 于 Web 的 软件 完全 是 另 一 回 事 。 在 写 第 一 行 代码 之 
前 就 做 出 非常 详细 的 说 明 书 仍然 有 些 好 处 , 但 这 没 能 充分 利用 到 这 种 
媒介 的 优势 。 每 天 、 每 小 时 或 是 随便 什么 时 间 ， 我 们 都 可 以 坐 在 舒适 
的 Aeron 座 椅 里 面 发 布 版 本 ， 而 且 基 本 没什么 成 本 。 

好 在 ， 作 为 一 个 行业 , 我 们 已 经 开始 打破 这 个 比喻 的 樊 笼 。 敏 捷 
开发 并 不 是 什么 革命 性 的 东西 , 无 非 是 把 我 们 从 一 个 旧 比 喻 的 束缚 里 
面 解脱 出 来 ,因为 旧 的 做 法 在 今天 已 经 不 像 在 过 去 那么 有 价值 了 。 这 
并 不 是 说 , 传统 的 瀑布 开发 模型 已 经 过 时 了 , 它 对 于 比较 复杂 的 大 软 
件 项 目 仍然 有 其 好 处 。 然 而 不 假 思 索 地 遵循 这 个 旧 比 喻 也 可 能 遮 住 我 
们 的 双眼 ， 妨 碍 我 们 采用 一 种 更 适合 自己 环境 的 新 方法 。 

“规划 、 规 划 、 规 划 ” 的 比喻 过 分 强调 要 花 大 量 时 间 计 划 让 所 有 
东西 号 于 完美 ， 而 忽视 了 可 以 用 好 实际 写 代 码 的 工夫 。 
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传统 上 , 我 们 把 发 行 日 期 看 做 一 个 关键 任务 点 ,软件 到 这 时 必须 
是 最 终 版 。 没 有 回头 路 了 。 

对 于 建筑 物 和 大 楼 结构 来 说 ， 这 是 最 基本 的 。 对 软件 而 言 ， 这 个 
比喻 曾几何时 也 是 有 道理 的 。 把 软件 装 在 软盘 和 CD 上 发 货 的 时 候 ， 
什么 东西 都 得 弄 对 了 。 有 了 bug 就 意味 着 要 花费 巨大 的 成 本 和 大 量 的 
时 间 。 为 了 追求 完美 或 是 塞 进 一 个 新 功能 ,项 目 就 得 不 断 拖延 。 我 在 
下 一 章 将 谈 谈 这 对 士气 会 有 什么 影响 。 

SK, SEF Web 的 程序 不 再 是 “发 行 ” 了 ， 而 是 上 传 、 发 布 、 
推送 了 。 软 件 会 随 着 时 间 的 推移 而 发 展 和 成 熟 。 

发 行 之 后 , 第 2、3 版 乃至 第 20 版 可 以 在 几 天 其 至 几 小 时 之 后 发 
布 。 甚 至 软件 的 正式 版 本 号 这 个 概念 也 过 时 了 。 这 只 有 在 用 磁盘 发 行 
软件 的 过 去 才 有 意义 。 

现在 , 我们 不 停 地 整合 ,不 断 地 反复 。 和 汽车 行业 不 一 样 ， 我 们 
用 不 着 大 批量 召回 。 如 今 ， 遇 到 关键 的 bug 可 以 立刻 打 补 丁 ， 进 行 测 
ik, 加 以 部 署 。 它 不 再 是 2.0 版 了 , 现在 是 2.0.12931 版 , 或者， 简单 
来 说 就 是 今天 当天 的 版 本 。 还 有 谁 会 因为 这 点 bug 盯 着 你 不 放 吗 ? 

社会 对 于 这 种 迭代 也 渐渐 习以为常 了 。 你 有 没有 看 到 Facebook 
上 的 新 图 片 库 ? 你 有 没有 看 到 Google 新 的 自动 提示 功能 ?” Twitter 的 
新 布局 呢 ? 没 人 再 去 搞 一 个 月 的 宣传 活动 来 提醒 你 了 。 新 的 变化 就 这 
样 天 天 在 出 现 。IMVU" 是 一 个 流行 的 3D 聊天 应 用 ， 号 称 有 1 亿 多 注 
册 用 户 ， 它 每 天 要 发 布 50 次 。 


D 参见 http://www.imvu.com。 
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在 如 今 的 系统 架构 下 ， 最 初 发 行 不 再 像 过 去 那样 ， 或 是 像 很 多 其 
他 行业 那样 ， 必 须 尘 埃 落 定 、 功 德 圆满 。 它 无 非 是 整个 软件 生命 周期 
HULA (Ja BILE ) 小 发 布 中 的 一 个 而 已 。 这 种 观点 可 以 减轻 发 
行 软件 的 精神 压力 。 

不 幸 的 是 ,这 种 观念 很 容易 就 被 滥用 了 。 不 要 把 这 种 概念 转变 当 
成 懒惰 或 者 是 无 限期 拖延 的 借口 。 应 用 软件 的 首次 发 行 版 应 当 是 在 别 
人 拿 到 之 前 就 非常 非常 好 了 。 大 的 方面 都 得 是 对 的 , 需要 有 完善 的 安 
全 系统 。 但 是 小 的 方面 , 那些 可 以 后 面 再 慢 慢 修复 的 东西 ,不 应 成 为 
发 布 软件 的 障碍 。 你 可 能 会 很 惊讶 , 你 在 发 行 软件 时 曾经 觉得 重要 的 
东西 突然 就 不 重要 了 …… 毕 况 现 在 已 经 送出 去 了 。 

在 软件 发 行 的 时 候 仍然 应 当 庆 祝 一 下 ， 把 整个 团队 拉 出 去 吃 一 
顿 大 餐 。 但 别 把 所 有 的 感情 都 倾注 在 “婚礼 ”上 ， 后 面 还 得 和 这 个 
软件 厢 磨 多 时 呢 ， 还 会 做 些 调整 ， 加 入 一 组 新 功能 ， 把 错 的 东西 搞 
对 ， 等 等 。 

发 行 无 非 是 软件 生命 中 的 一 个 点 而 已 ,不 是 尘埃 落 定 ,也 不 是 功 
rae 


=>) 
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“技术 架构 师 不 应 该 再 写 代 码 ” 这 种 说 法 ， 我 从 来 都 不 以 为 然 。 

在 建筑 行业 ， 建筑 师 躲 进 了 象牙 塔 ， 他 们 的 生活 里 只 有 规划 ,不 
会 去 敲 钉 子 或 是 焊接 颖 。 让 建筑 师 去 做 钻 洞 或 是 铺 混 凝 土 这 种 体力 
活 根 本 就 是 不 可 行 的 。 建 筑 设计 和 建筑 施工 这 两 种 职业 可 谓 是 泾 渭 
分 明 。 


做 官 越 大 ， 编 程 越 少 


在 我 们 这 个 行当 , 技术 架构 师 这 个 职位 是 通过 实 实在 在 的 开发 得 
来 的 一 一 就 是 建造 应 用 程序 的 “体力 活 ”。 但 是 ， 在 大 多 数 公司 里 ， 
当 职 位 逐 级 柳 上 软件 开发 的 阶梯 时 , 代码 反倒 写 得 少 了 。 我 们 越 来 越 
沉浸 在 规划 里 , 而 不 是 去 第 一 线 发 现 问 题 。 我们 更 关心 的 是 总 体 的 图 
R, 而 不 是 代码 的 细 校 末节 。 在 我 们 这 个 行业 里 , 一 直 都 有 一 种 理念 ， 
就 是 架构 师 应 该 做 规划 ， 程 序 员 才 应 该 做 开发 。 

于 是 造成 了 一 个 错误 的 印象 ， 就 是 如 果 你 达到 了 某 个 水 平 ， 杀 自 
编程 就 不 再 是 最 有 价值 的 工作 了 , 只 要 把 脏 活 累 活 留 给 初级 程序 员 就 
行 了 ! 与 此 同时 , 这 也 让 低 阶层 的 程序 员 不 再 去 思考 整体 目标 和 项 目 
的 走向 ， 我 们 只 是 要 求 他 们 集中 精力 做 实现 。 这 种 架构 师 -程序 员 的 
分 工 模式 让 双方 对 应 用 软件 这 个 整体 承担 的 责任 更 少 了 。 

我 们 把 职责 强行 分 成 了 某 种 层级 ,有些 人 考虑 的 是 “整体 技术 方 
案 "”， 还 有 些 人 只 是 思考 什么 if 语句 、for 循环 还 有 标识 符 之 类 的 ， 
这 就 会 把 本 来 紧密 联系 的 两 个 行当 割裂 开 来 。 

纯粹 的 技术 架构 师 可 能 构思 的 是 最 优 的 构架 、 最 优 的 设计 模式 或 
是 最 佳 实践 什么 的 。 但是， 只 有 亲自 上 手 , 埋头 在 代码 里 的 时 候 , 他 
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们 才能 了 解 真正 的 难点 在 哪里 。 与 此 同时 , 那些 无 权 做 高 层次 构思 的 
程序 员 也 没有 机 会 提出 不 同意 见 。 常常 是 真正 做 实现 的 人 才能 最 清楚 
地 看 到 前 面 的 障碍 。 

对 于 架构 师 - 程 序 员 这 个 例子 已 经 谈 得 太 多 了 。 软 件 行业 的 公司 
阶梯 需要 一 个 更 好 的 模式 。 

要 盖 一 座 建 筑 ， 设计 师 做 设计 ， 开 发 商 做 开发 。 传 统 的 建筑 师 知 
道 如 何 做 详尽 的 规划 ,每 个 细节 都 规定 得 清 清楚 楚 。 但 是 他 们 不 会 自 
己 动手 去 盖 ， 因 为 这 完全 没 道理 。 做 高 层次 构思 和 在 地 沟 中 干 活 的 这 
种 分 野 ， 主 要 是 根据 两 种 角色 的 实际 情况 决定 的 。 

软件 行业 就 不 一 定 是 这 样 了 。 伟 大 的 程序 员 可 以 同时 在 “地 沟 ” 
和 “高 层 ”之 间 游 思 有 余 。 当 然 ， 架 构 师 可 能 大 部 分 时 间 都 在 做 高 层 
次 的 构思 ， 但 也 应 该 对 开发 有 所 涉足 ,来 了 解 整个 的 情况 。 


找 时 间 写 代码 


在 很 多 技术 公司 里 , 我 前 面 提 的 这 一 条 根本 行 不 通 。 大 多 数 技术 
架构 师 全 天 都 在 和 公司 里 面 的 其 他 部 门 开 会 , 他 们 还 经 常 被 拉 去 和 客 
户 打 电话 , 讨论 软件 项 目 面临 的 种 种 技术 难题 。 那 到 底 什么 时 间 去 写 
代码 呢 ? 

在 我 的 某 个 全 职 网 络 开发 作坊 创立 几 个 月 后 , 我 们 聘用 了 一 个 新 
的 高 级 架构 师 Adam。 他 来 了 以 后 ， 给 我 们 年 轻 的 网 络 程序 员 团 队 定 
下 了 一 个 非常 不 同 的 基调 。 除了 所 有 日 常 的 本 职工 作 之 外 , 很 显然 他 
对 代码 怀 有 激情 。 我 马上 就 感觉 到 我 似乎 只 是 在 和 男 外 一 个 程序 员 对 
话 一 一 虽然 他 比 我 聪敏 也 害 智 得 多 。 我 们 之 间 的 架构 师 -程序 员 关 系 
让 我 个 人 也 深 深 受益 。 

我 们 的 第 一 个 项 目 是 给 一 家 大 的 律师 事务 所 做 外 部 网 。Adam 提 
到 一 些 关于 代码 生成 的 事情 , 我 听 了 觉得 跟 科 幻 似 的 。 但 是 我 很 快 就 


图 灵 社 区 会 员 cindy282694 专 享 尊重 版 权 


14 第 2 章 比 喻 


RM, 底层 服务 右 端 的 对 象 、 查 询 以 及 我 要 手写 的 那些 方法 大 部 分 部 
是 算法 性 的 , 很 多 都 可 以 从 外 部 网 的 数据 库 模 式 (schema ) 中 演绎 出 
来 。Adam 建议 我 不 要 暴力 开发 埋头 昔 干 ， 而 是 要 重点 建立 一 套 定制 
表单 和 屏幕 ,他 自己 则 着 手写 一 个 代码 生成 器 。 他 每 天 利用 坐 火 车 上 
下 班 的 一 个 小 时 写 代码 , 连续 做 了 几 个 礼拜 。 很 快 就 有 了 一 套 虽然 粗 
陋 却 很 强劲 的 工具 ， 可 以 生成 本 来 需要 手写 的 很 多 东西 。 

我 们 在 代码 生成 上 的 小 小 分 卜 所 浪费 的 时 间 , 在 开始 使 用 代码 生 
成 囊 之 后 很 快 就 弥补 回来 了 。 每 次 改动 数据 库 模式 ,他 就 运行 那个 奇 
妙 的 小 程序 ， 重 新 生成 继续 制作 软件 所 需 的 所 有 代码 。 很 快 ，Adam 
的 努力 所 带 来 的 价值 超过 了 他 写 工具 的 成 本 。 并且 , 这 个 工具 我 们 还 
可 以 一 直 一 直 用 下 去 。 

所 以 , 虽然 我 是 项 目的 首席 程序 员 , 但 Adam 对 开发 也 参与 了 很 
多 。 如果 我 需要 一 些 不 同 的 算法 代码 , 他 就 在 下 班 回 家 的 火车 上 把 新 
功能 加 到 生成 天 里 去 。 第 二 天 , 我 就 有 了 一 套 新 代码 ， 再 也 不 用 手写 
了 。 我 在 那 几 个 月 里 学 到 的 东西 至 今 让 我 获 益 菲 浅 。 

在 你 沿 着 程序 员 的 职务 序列 ， 从 程序 员 一 步 步 变 成 架构 师 时 ， 别 
忘 了 代码 才 是 把 这 些 角 色 融 合 在 一 起 的 烙 合 剂 。 可 能 不 是 坐 火车 的 时 
间 ， 却 可 以 是 工作 中 的 一 个 小 时 、 两 个 小 时 ， 专 心 致 志 ， 只 写 代码 。 
你 可 以 在 第 23 篇 中 找到 在 编码 时 间 心 无 劳 合 的 方法 。 最 后 我 强调 一 
点 ,无论 你 在 开发 团队 中 的 职务 级 别 如 何 ， 都 要 坚持 写 代码 , 这 正 是 
你 最 有 价值 的 地 方 。 
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最 近 , 我 有 个 同事 Mustafa 说 我 “又 在 做 这 个 ”。 我 是 在 收纳 代码 
(code hoarding ): 把 我 觉得 再 也 用 不 上 的 代码 注释 掉 。 虽 然 我 们 对 所 
有 源 代码 都 有 版 本 控制 ( 你 绝对 也 应 该 这 么 做 )， 但 我 实在 没有 勇气 
把 它们 都 删 掉 。 因 为 我 随时 都 可 以 找 回 那些 上 昌 代 码 , 所 以 能 直接 删 掉 
的 时 候 ， 就 没 必要 注释 掉 了 。 

收纳 代码 算是 那 种 表面 上 看 起 来 很 正确 的 习惯 之 一 。 这 是 从 其 他 
基础 工程 行业 里 沿用 过 来 的 ， 却 不 太 适 合 编程 。 如 果 要 造 一 辆 车 , 我 
们 可 能 会 把 所 有 废 铜 烂 铁 都 收 起 来 , 因为 日 后 还 可 能 用 到 , 直接 扔 掉 
实在 太 轴 春 了 。 传 统 工程 里 面 ， 人 工 和 材料 非常 重要 。 现 实生 活 中 ， 
在 差不多 成 型 的 东西 上 修 修补 补 比 全 部 推翻 重 来 要 容易 多 了 。 

可 是 编程 的 时 候 , 我 们 却 容易 太 过 强调 这 种 因素 。 我 们 的 工作 真 
的 是 劳动 密集 型 的 吗 ?” 也 不 是 。 打字 算 不 上 是 什么 重 体 力 活 。 那 需要 
什么 材料 吗 ? FEELS SIN BSE OR BCA BB “BERL” IX TIVE RA 
库存 短缺 。 

与 此 同时 ,收纳 代码 实际 上 是 制造 了 更 多 的 障碍 。 多 数 时 候 的 实 
际 情况 是 , 我 从 来 不 会 把 几 天 前 或 者 几 个 星期 前 注释 掉 的 代码 再 去 掉 
注释 。 可 我 手头 正在 写 的 代码 周围 却 满 是 这 一 大 块 一 大 块 的 灰色 垃 
圾 ,看 起 来 就 烦 。 每 次 我 干 活 的 时 候 ， 周 围 的 旧 代 码 总 会 让 我 分 神 ， 
没 法 专注 在 眼前 最 重要 的 事情 上 。 

即使 我 确定 要 重新 实现 我 前 一 阵子 写 过 的 东西 , 早先 注释 掉 的 东 
西 一 般 来 说 也 无 论 如 何 用 不 上 。 我 可 能 把 其 他 地 方 的 逻辑 动 过 了 , 旧 
代码 里 面 引用 的 对 象 或 者 方法 可 能 也 变 了 。 比 起 重新 干 干净 净 地 把 代 
码 写 对 ， 要 把 这 旧 代 码 救 活 ,我 得 花 上 更 多 的 时 间 在 那儿 东 敲 西 补 。 
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上 周 的 代码 是 “上 周 旧版 的 我 ” 写 的 ， 那 个 我 只 知道 上 周 版 本 的 软件 
是 什么 样 的 。 

不 要 把 代码 转 积 在 注释 里 ， 删 除 代 码 可 以 让 代码 库 精 简 。 眼 前 的 
页 面 应 该 精确 地 反映 出 软件 现在 的 工作 方式 ， 一 分 不 多 ， 一 分 不 少 。 
现在 就 扔 掉 旧 代码 ， 在 编程 中 间 就 不 用 跳 过 一 堆 不 相干 的 垃圾 字 节 。 
我 们 以 后 也 用 不 着 去 琢磨 , 这 一 大 团 已 经 注释 掉 可 看 起 来 还 很 重要 的 
代码 ， 到 底 还 是 不 是 那么 重要 。 
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第 6 篇 多 元 化 胜 于 专业 化 


在 软件 行业 ,我 们 可 以 身 兼 设计 师 、 程 序 员 和 数据 库 管理 员 。 一 
个 人 可 以 精通 PHP、Java、.NET、C++、Python、SQL， 还 可 以 了 解 
HTML, CSS, JavaScript 和 Flash。 但 似乎 很 少 有 人 能 够 轻松 地 跨越 
用 户 界面 和 后 端 之 间 的 界限 。 

在 传统 建筑 行业 里 , 让 电工 兼任 水 泥 浇 铸 工 , 或 者 让 铺 砖 工 去 装 
管道 都 是 不 现实 的 事情 。 他 们 都 各 有 专长 ,各 司 其 职 。 他 们 现实 中 也 
不 会 呆 在 一 起 。 出 于 智力 和 实际 考虑 ,这 种 情况 就 要 求 有 一 群 专 精 的 
从 业者 去 磨炼 各 自 的 手艺 。 

但 把 同样 的 理念 移植 到 我 们 这 个 行业 就 不 大 站 得 住 脚 了 。 我 们 工 
作 所 用 的 工具 无 非 就 在 眼前 的 这 块 屏 幕 上 。 如果 正在 搞 SQL, 也 用 不 
着 要 换个 地 方才 能 写 HTML 或 者 是 在 Photoshop 里 面 弄 上 一 张 图 , 只 
要 在 计算 机 上 切换 程序 就 行 了 。 编程 的 科目 之 间 , 没有 任何 物理 上 的 
障碍 。 

此 外 ,很 多 软件 概念 是 超越 语言 ， 甚 至 经 常 是 超越 领域 的 。 模 型 
-视图 -控制 器 ( Model-View-Controller MVC ) 是 一 种 应 用 程序 架构 ， 
被 许多 用 户 界 面 平 台 ( 如 Adobe Flex 的 Cairngorm 平台 ) 采用 , 还 用 
在 .NET 等 许多 服务 器 端 开 发 框架 上 。 现 在 的 编程 语言 之 间 有 大 量 的 
重合 。 设 计 模 式 和 重 构 这 些 概念 在 编程 的 世界 里 随处 可 见 。 

在 我 的 公司 里 , 开发 团队 的 大 部 分 人 员 都 了 解 多 种 编程 语言 ， 同 
时 兼 做 前 端 和 后 端 。 这 可 以 帮 有 我 们 平衡 每 个 人 的 工作 量 ， 因 为 大 家 都 
可 以 很 熟练 地 在 软件 的 所 有 层面 上 工作 。 

一 个 人 可 以 同时 是 .NET 程序 员 、HTML 标准 能 手 和 数据 建 模 专 
Ko 我 们 可 能 对 这 个 或 者 那个 精通 、 有 兴趣 ,但 没 理 由 不 能 在 多 个 领 
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域 大 显 身 手 。 


“我 过 去 是 做 先进 商业 平台 解决 方案 的 ， 现 在 我 无 非 是 把 东西 搞定 。 
为 什么 伟大 的 程序 员 不 能 同时 是 优秀 的 用 户 界面 设计 师 呢 ? 我 


性 。 从 概念 上 说 ,设计 用 户 界 面 和 设计 坚实 的 软件 架构 差 得 并 不 远 。 
出 色 而 好 用 的 用 户 界面 要 直观 易学 、 组 织 清楚 、 扩 展 自 如 、 目的 明确 。 
这 和 软件 设计 所 推崇 的 许多 特质 是 吻合 的 。 

反 过 来 也 是 一 样 。 才 华 横 溢 的 用 户 界面 设计 师 中 , 认为 自己 有 能 
力 成 为 编程 高 手 的 太 少 太 少 了 。 可 能 程序 员 觉 得 用 户 界面 设计 是 要 让 
东西 “漂亮 ,而 设计 师 看 编程 就 是 要 写 很 多 “技术 玩意 ”。 可是, 他 
们 的 共性 远 比 这 个 要 多 得 多 。 

归根 结 底 , 无 论 是 上 层 界面 , 还 是 底层 引擎 ， 软 件 设 计 的 目标 是 
一 臻 的。 我 们 没有 理由 不 能 在 多 个 领域 都 做 得 出 色 。 
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第 7 篇 ”比喻 渐 欲 迷人 有 眼 


我 们 已 经 知道 了 为 什么 比喻 可 能 会 影响 我 们 处 理 软件 的 方式 。 如 
果 过 分 强调 比喻 , 就 可 能 在 这 些 不 实 的 印象 中 养 成 一 些 坏 习 惯 。 比 喻 
的 害处 还 不 止 如 此 , 它们 不 仅 会 降低 我 们 做 事情 的 效率 ,而 且 还 会 妨 
碍 我 们 思考 更 好 的 方法 来 做 一 件 事 。 

线 框图 和 详尽 的 规划 占用 了 实际 构建 和 审查 的 时 间 , 也 不 能 利用 
我 们 能 够 不 断 迭 代 的 优势 。 它 们 让 人 在 一 行 代码 都 没有 写 的 时 候 , 就 
要 把 整个 写 代 码 的 过 程 想 一 个 过 。 

对 于 发 行 的 过 分 强调 掩盖 了 一 个 事实 , 就 是 今天 的 软件 已 经 可 以 
比较 容易 地 修改 和 重新 发 布 了 。 我 们 不 再 “发 货 ”， 而 只 是 从 互联 网 
上 下 载 ， 或 者 软件 本 号 就 是 基于 Web 的 。 要 是 发 行 日 期 因为 某 些 必 
须要 塞 进去 的 功能 推迟 了 ， 就 会 伤害 到 程序 员 的 士气 。 这 对 于 开发 团 
队 来 说 完全 就 是 压 哨 绝 杀 。 

软件 开发 中 的 传统 职责 分 工 ， 即 架构 师 、 程 序 员 和 项 目 经 理 的 划 
分 , 压抑 了 那些 在 多 个 领域 都 有 才华 的 人 。 一 个 人 可 以 同时 是 有 远见 
的 规划 师 、 周 到 细致 的 程序 员 和 优秀 的 沟通 者 。 严 格 遵 循 传 统 的 比喻 
妨碍 了 真正 有 才华 的 人 去 接触 这 个 行业 中 的 各 种 机 会 。 

要 绕 开 这 个 问题 , 一 种 方式 是 找到 一 个 更 合适 的 比喻 。 开 发 软件 
可 能 和 写 小 说 或 者 作曲 更 相近 。 想 想 这 些 专业 的 人 士 是 如 何 “ 规 划 ” 
他 们 的 工作 的 。 

作家 可 能 会 列 一 个 章 回 提纲 , 想 想 大 致 要 写 些 什么 。 但 接 下 来 就 
马上 着 手写 具体 的 东西 , 然后 再 反复 编辑 修改 一 一 这 里 动 一 个 词 , 那 
里 删 掉 一 章 。 写 作 的 过 程 和 我 们 编程 非常 相似 。 

音乐 家 也 不 会 一 连 好 几 个 月 都 在 写 谱 子 , 然后 希望 这 谱 子 一 次 写 
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就 。 他 会 不 断 地 弹 奏 、 试 验 ， 然后 找到 一 个 合适 的 即兴 片段 。 也 可 能 
会 先 有 几 行 歌词 ， 然 后 再 配 上 正确 的 和 弦 ,， 或 者 是 反 过 来 。 歌 是 一 点 
点 写 好 的 ， 然 后 一 段 段 试验 出 来 的 。 

在 这 两 个 例子 里 面 ， 材 料 的 成 本 都 是 很 低 的 。 纸 笔 都 是 现成 的 ， 
吉他 也 不 是 按 音符 收费 的 ， 声 音 也 没有 成 本 。 同 样 道 理 ， 代 码 是 我 
们 拥有 的 廉价 材料 。 一 旦 我 们 把 开发 环境 搭 好 ,， 写 代码 没有 什么 材料 
成 本 。 

所 以 如 果 你 面 对 一 个 软件 问题 不 知 如 何 下 手 , 或 者 没有 足够 的 
信息 来 做 出 明智 的 决定 , 那么 一 开始 用 传统 的 开发 比喻 作为 基础 还 是 
不 错 的 。 但 如 果 你 已 经 投入 那个 比喻 一 段 时 间 ， 就 需要 抬头 看 看 了 ， 
看 看 它 在 哪些 方面 促进 又 在 哪些 方面 影响 着 你 的 流程 。 

知道 了 这 些 , 现在 就 很 清楚 我 们 依赖 的 流程 是 不 是 真 的 有 效 。 下 
一 步 就 要 着 眼 于 长 远 了 。 如 何在 程序 开发 的 职业 生涯 中 一 直 干 劲 十 足 
呢 ? 接 下 来 我 们 就 来 讨论 几 种 保持 干劲 的 方法 。 
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不 管 你 有 多 牛 ， 如 果 没 有 写 代 码 的 动力 ， 那 就 拉倒 吧 。 会 计 哪怕 
没什么 动力 也 能 把 数据 表 填 完 ,出纳 也 可 以 当 一 天 和 尚 撞 一 天 钟 , 但 
没有 动力 的 程序 员 可 真 的 能 让 一 个 软件 项 目 彻底 失败 。 

动力 还 必须 是 可 持续 的 , 在 开发 过 程 中 必须 不 断 挖掘, 不 断 培养 。 
项 目 初 期 让 你 写 代 码 时 干劲 十 足 的 那些 因素 , 可 能 并 不 是 项 目 收尾 时 
的 动力 源 果 。 在 制作 软件 的 过 程 中 , 在 不 同 的 时 间 点 ， 可 能 有 不 同 的 
东西 促使 你 前 进 。 

保持 动力 的 问题 并 不 仅 限于 软件 行业 , 在 媒体 上 我 们 一 直 都 能 见 
到 各 种 例子 。 签 了 好 几 百 万 美元 巨额 合约 的 大 牌 运动 员 , 现在 打 比 赛 
的 时 候 不 拼 尽 全 力 了 ; 陪伴 我 们 成 长 的 乐队 , 现在 开始 粗制滥造 发 专 
辑 捞 钱 了 。 即 使 有 惊人 的 财富 做 保障 ， 很 多 名 人 到 后 来 也 都 疲 省 了 。 
这 些 都 证 明 ， 仅 仅 一 件 事 不 足以 维持 动力 。 

我 们 需要 多 种 方式 来 让 激情 在 血管 中 不 断 奔 涌 。 美 食 评 论 家 的 评 
论 可 以 让 大 厨 不 敢 懈 人 铺 , 但 餐馆 生意 红火 、 员 工 心情 愉快 也 能 做 到 这 
一 点 。 好 用 的 工具 也 有 助 于 维持 动力 ,如 果 给 超级 大 厨 一 套 高 质量 的 
刀具 和 一 些 新 鲜 原 料 , 那 就 是 见证 奇迹 的 时 刻 了 。 开 和 餐馆 的 动力 来 自 
于 各 种 不 同 的 方面 ， 开 发 软件 也 是 一 样 。 
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第 8 篇 工作 即 福利 


在 我 们 这 个 行业 里 ,长 久 的 动力 并 不 来 自 于 福利 。 当 然 ， 高 薪 和 
免费 午餐 确实 不 错 ， 能 随时 玩 玩 桌 上 足球 机 也 不 赖 。 但 归根 结 底 , 长 
入 的 动力 来 自 于 我 们 所 做 的 工作 。 我 所 见 到 的 每 个 有 激情 的 程序 员 ， 
在 谈论 起 经 过 长 时 间 音 苦 思 索 才 为 技术 问题 找到 的 优雅 解决 方案 时 ， 
都 异常 兴奋 , 这 比 说 起 在 公司 编程 大 会 上 记得 10% 的 加 薪 要 兴奋 得 多 。 


福利 并 不 是 长 期 的 动力 


正 是 出 于 这 个 原因 ， 当 一 次 又 一 次 看 到 很 多 人 , 尤其 是 那些 无 优 
无 虑 、 只 需 月 付 房租 的 年 轻 人 ， 仅 仅 为 了 稍 高 一 点 儿 的 工资 和 奖金 ， 
就 揭 强 接受 索然 寡 味 的 新 工作 时 ， 我 就 感到 十 分 困惑 。 


“我 不 知道 ， 最 近 就 是 没 啥 能 让 我 提起 兴趣 了 ……” 


不 要 只 因为 加 薪 就 耗 在 你 痛恨 的 工作 上 , 把 这 种 工作 思路 留 给 那 
些 就 为 了 挣 钱 而 编程 ， 然 后 消磨 时 光 企 盼 周 末 的 人 吧 。 
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如 果 工 资 X 和 工资 X*1.05 的 区 别 无 非 是 一 年 中 多 在 城 里 疯狂 几 

夜 的 话 , 还 是 去 做 那些 解决 更 有 趣 问题 的 工作 吧 , 或 者 选择 那些 员工 
更 有 激情 的 工作 。 去 那些 有 机 会 漂亮 地 做 出 东西 的 地 方 , 在 这 里 真实 
的 项 目 才 是 大 家 的 兴趣 核心 。 你 在 工资 上 所 牺牲 的 ( 如果 你 真 的 需要 
牺牲 的 话 )， 将 在 幸福 感 上 得 到 更 多 弥补 。 
好 公司 的 一 个 标志 就 是 它 对 待 项 目的 方式 。 好 的 项 目 有 明确 而 具 
体 的 目标 。 好 的 项 目 要 么 万 事 俱 备 , 要 么 有 做 到 万 事 俱 备 的 计划 。 好 
的 项 目 既 有 宏伟 的 目标 , 又 经 过 周密 的 思考 。 好 的 项 目 有 确定 的 交付 
时 间 , 而 不 是 时 间 和 预算 都 含糊 不 清 。 这 种 项 目 给 工作 设立 了 一 个 目 
标 。 我 参与 的 编程 项 目 数 以 百 计 , 所 有 好 的 项 目 都 有 这 些 给 人 动力 的 
特质 。 


福利 可 能 是 毁灭 性 的 

甚至 有 证 据 表明 ， 表 面 化 的 福利 实际 上 会 前 弱 人 们 工作 的 积极 
性 。 是 的 , 在 我 们 面前 晃动 的 胡萝卜 可 能 让 我 们 更 加 没有 工作 的 热情 。 

《纽约 时 报 》 畅 销 书 作者 Dan Pink 有 一 个 很 棒 的 TED 演讲 , 是 关 
于 令 人 惊奇 的 动机 科学 的 。 "他 说 传统 的 商业 激励 因素 ， 比 如 大 笔 奖 
金 , 可 能 会 成 功 调动 员工 的 积极 性 , 但 只 能 用 于 那些 简单 琐碎 的 工作 ， 
类 似 于 把 数据 从 一 张 表 填 到 另 一 张 表 这 样 的 工作 。” 

相反 , 那些 需要 批判 性 分 析 和 创造 性 解决 方案 的 工作 ， 就 像 我们 
每 天 面 对 的 这 些 ,把 金钱 奖励 挂 在 员工 眼前 晃 悠 则 没什么 用 处 。 在 一 
些 涉 及 高 层次 思考 的 实验 中 , 金钱 激励 和 业绩 之 间 是 负 相 关 的 : 给 一 
组 特定 研究 对 象 的 金钱 奖励 越 多 , AUT a Ae. HPA 
很 有 吸引 力 的 项 目 来 说 ， 额 外 的 金钱 奖励 反而 让 工作 不 那么 诱 人 了 1! 


参见 http://www.ted.com/talks/dan_pink_on_motivation.html, 
如 果 想 看 原文 , 请 参阅 他 的 Drive: The Surprising Truth About What Motivates Us [Pin09]。 
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对 我 来 说 ， 做 的 是 什么 并 不 那么 重要 , 可 以 是 只 有 一 个 页 面 的 网 
站 、 搜 索引 擎 、 在 线索 引 卡 、 交 互 性 地 图 或 是 游戏 。 产 品 可 以 供 几 百 
HAH, 几 千 人 用 , 或 是 仅 供 八 个 人 使 用 。 我 做 的 可 以 是 持续 六 个 月 
的 项 目 ,也 可 以 是 两 个 小 时 的 练习 。 我 可 以 大 部 分 时 间 在 写 标记 、 做 
用 户 界面 、 写 服务 器 端 代码 , 或 是 搭建 数据 库 。 总 而 言 之 , 不论 在 做 


什么 样 的 工作 ,只 要 知道 有 机 会 
很 有 激情 。 


央 作 优美 的 东西 ， 我 就 会 对 这 个 工作 


在 选择 下 一 份 工作 的 时 候 , 记 住 那个 能 够 让 我 们 长 期 保持 干劲 的 


东西 


不 是 外 部 的 福利 ， 而 是 工作 本 身 。 
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有 时 候 ， 最 难 找到 动力 的 地 方 就 是 最 开始 。 光 是 想 想 编 码 是 很 容 
易 的 ,软件 在 我 们 脑子 里 面 编译 的 时 候 都 完美 极 了 , 我 们 不 会 纠结 于 
将 要 面 对 成 百 上 千 个 小 障碍 。 可 一 旦 真 的 动手 写 起 来 ,就 完全 是 另外 
一 人 码 事 了 ， 激 情 很 快 就 会 消退 。 

写 软件 的 体会 和 写 这 本 书 没什么 两 样 , 我 在 琢磨 要 写 什么 内 容 时 
所 花 的 时 间 比 实际 动笔 的 时 间 多 得 多 。 写作 有 时候 真 是 一 种 吸 人 脑 散 
的 游戏 ,其 中 充斥 着 了 无 生 趣 的 字句 ,时 不 时 还 会 思路 卡 壳 或 疲倦 不 
堪 。 面 对 那些 消磨 士气 的 因素 时 ， 还 想 文思 果 涌 是 很 难 的 。 

Natalie Goldberg 的 Writing Down the Bones [Gol05] 一 书 从 头 至 尾 
都 在 讲 写作 者 的 动力 。 她 给 了 一 个 人 手 小 提示 ， 即 不 要 去 想 什 么 宏大 
的 开篇 , 而 是 从 故事 的 中 间 找 个 地 方 开始 写 , 从 最 有 意思 的 地 方 开始 ， 
并 且 立 即 开 始 ， 不 要 试图 从 头 写 起 。 

我 们 总 是 花 很 多 时 间 琢 磨 那个 宏大 的 、 抓 人 眼球 的 开篇 ， 而 实际 
E, 这 对 于 整个 故事 来 说 是 相当 无 关 紧要 的 一 部 分 , 写 完 开篇 的 那 
段落 之 后 还 有 无 数 的 工作 要 做 。 我 写 这 本 书 时 就 没有 从 头 写 起 , RE 
东西 永远 都 不 是 线性 的 过 程 。 开 始 的 时 候 , 要 是 某 个 话题 让 我 有 了 有 灵 
感 ， 我 就 写 这 个 话题 。 

这 种 思路 也 可 以 用 在 开发 软件 上 。 我们 不 一 定 非 要 先 做 首页 ， 再 
做 子 页 面 ,也 不 一 定 非 要 在 业务 逻辑 之 前 先 搭 数据 库 。 写 软件 不 用 非 
得 一 上 手 就 从 头 开 始 , 我 们 可 以 从 最 感 兴趣 的 地 方 人 手 。 这 种 优越 性 
是 造 很 多 其 他 东西 时 所 无 法 享受 的 ， 比 如 造 房子 、 造 汽车 或 者 造 任何 
实际 的 东西 。 我们 并 不 一 定 要 从 某 个 特定 的 地 方 人 手 , 许多 东西 都 可 
以 事后 重 构 。 也 许 这 是 绕 了 一 点 弯路 , HUR- EU Ne 
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所 以 ,如 果 你 可 以 选择 从 什么 地 方 开始 写 软件 , 一定 要 利用 这 份 
自由 ， 挑 一 个 你 觉得 最 有 意思 的 功能 ， 从 那里 开始 做 。 

这 在 着 手 做 一 个 大 型 软件 项 目 时 尤其 有 用 。 用 不 着 花 上 三 天 时 间 
来 框 定 一 个 进度 表 和 发 布 日 期 , 不 如 用 这 工夫 写 你 最 感 兴趣 的 那 部 分 
程序 。 过 一 个 礼拜 ,你 就 会 知道 自己 到 底 有 多 少 动力 ， 对 于 其 他 部 分 
何 时 能 够 搞定 也 会 心中 有 数 。 

如 果 你 发 现 自己 就 是 三 分 钟 热度 ， 那 么 及 时 停止 ， 损 失 也 不 大 。 
不 过 大 部 分 时 候 , 你 会 发 现 写 软件 这 种 让 人 望 而 生 鞭 的 工作 , 其 实 也 
不 是 不 能 完成 的 。 用 三 天 (或 者 一 个 礼拜 ) 踏 踏实 实地 去 写 程 序 ,， 你 
会 对 自己 在 做 的 东西 以 及 剩 下 的 部 分 何 时 能 够 完成 有 更 多 的 了 解 。 有 


了 一 点 灵感 并 做 出 了 一 点 点 成 绩 之 后 , 再 去 制定 一 个 切合 实际 的 时 间 
表 就 容易 多 了 。 
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第 10 篇 SKE 


每 个 有 激情 的 程序 员 最 关心 的 就 是 自己 的 代码 。 代 码 就 是 我 们 的 
画板 。 就 算 没 有 一 个 用 户 会 看 这 些 代码 一 眼 ， 有 激情 的 程序 员 也 会 一 
行 一 行 地 埋头 若 写 下 去 。 即 使 我 们 知道 ， 清 清楚 楚 地 知道 ， 自 己 所 做 
的 不 过 是 面向 极 少数 人 的 一 个 小 程序 , 但 我 们 很 多 人 仍然 会 关心 程序 
在 最 广阔 的 舞台 下 表现 如 何 。 我 们 关心 代码 在 最 严 苟 的 条 件 下 的 性 
能 ， 并 试图 减少 对 服务 器 、 对 服务 、 对 数据 库 的 匈 余 调 用 。 

然而 ， 要 在 这 个 行业 中 生存 下 来 ， 你 最 好 不 是 个 完美 主义 者 ， 因 
为 没有 什么 软件 是 完美 的 , 特别 是 基于 网 络 的 软件 。 我 们 的 产品 是 通 
过 用 户 存活 下 来 的 。 用 户 基 数 增长 的 时 候 , 它 会 发 生 巡 变 。 新 功能 会 
不 断 呈 现 ， 新 bug 也 会 不 断 产 生 ， 所 以 要 求 完 美 实在 让 人 筋疲力尽 。 

一 个 程序 员 最 开始 写 下 第 一 行 代 码 时 所 采用 的 方法 , 和 他 今天 所 
用 的 方法 很 可 能 大 相 径 庭 。 软 件 会 随 着 时 间 变 化 。 我 们 编写 、 调 整 、 
反复 ， 有 了 时候 还 得 重 写 ， 所 以 最 好 能 适应 这 一 点 。 

开发 的 时 候 , 往往 要 做 很 多 权衡 ,是 追求 性 能 还 是 追求 代码 简洁 
性 ， 是 要 完美 的 构架 还 是 要 可 维护 性 ， 等 等 。 没有 什么 “高 招 ”能 够 
确定 某 种 方式 就 一 定 是 对 的 。 

一 个 伟大 的 程序 员 会 痴迷 到 有 强迫 症 ， 但 也 一 直 都 能 接受 不 完 
K, 想 要 写 出 “完美 的 代码 ”会 让 你 骑 虎 难 下 。 我 们 越 早 接受 不 完美 ， 
就 越 能 保持 干劲 、 坚 持 到 底 ， 最 后 完成 的 工作 也 会 越 多 。 


>+ 
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第 11 篇 休止 一 下 


你 可 能 是 程序 写 得 太 多 了 ，。 

当 你 pene 贯 注 地 工作 的 时 候 , 当 你 的 大 脑 完 全 沉浸 在 代码 里 的 时 
候 ， 当 你 的 手眼 脑 在 协同 工作 的 时 候 , 停 下 来 。 抬 起 头 来 ， 想 想 这 一 
RIS TIET AMR, REHM, HAR 


I SMELL THE 


D ZOSE= R 


perve-TH2ZU 


ql 


编程 ， 虽 然 是 一 种 脑力 劳动 , Bt PR EE 

的 时 候 一 般 都 坐 着 , 消磨 了 几 个 小 时 之 后 ,我 们 在 椅子 里 会 越 缩 越 低 。 

有 些 人 甚至 一 边 编 程 一 边 吃 喝 , 只 要 看 看 键盘 就 知道 了 一 一 键 面 光 滑 
玉 润 ,下 面 却 藏 着 几 斤 饼干 漆 。 

这 种 舒适 是 很 危险 的 。 这 意味 着 一 做 起 来 就 是 好 几 个 小 时 ,都 没 
意识 到 我 们 消耗 了 多 少 体力 。 

当代 码 开始 变 得 有 点 拖 省 的 时 候 一 一 或 者 , 最 好 是 在 这 之 前 一 一 
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就 停 下 来 。 良 好 的 编程 习惯 是 在 精力 充沛 时 高 效 地 工作 ， 而 不 是 一 味 
地 采 在 屏幕 前 。 两 个 小 时 的 高 质量 编程 胜 过 八 个 小 时 的 郁 效 。 我 们 编 
程 编 累 了 的 时 候 ， 更 容易 走 个 捷径 , 或 是 违反 标准 规范 。 那 些 低 效 的 
时 间 最 后 都 写 了 些 坏 代码 一 一 我 们 第 二 天 就 可 能 后 悔 的 代码 。 所 以 ， 
请 缩短 编程 时 间 ， 出 去 走 走 ， 享 受 一 下 生活 吧 。 
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第 12 篇 早起 先 测 试 


早起 上 班 第 一 件 事 : 测试 你 的 软件 。 这 是 你 最 清醒 、 最 有 动力 写 
点 好 东西 的 时 候 。 

在 一 天 的 工作 中 , 我 们 花 了 那么 多 力气 去 写 代码 , 根本 没 精神 再 
去 挨 段 测试 了 。 一 天 下 来 ,会 越 来 越 难以 统 览 全 局 。 到 了 傍晚 ， 人 已 
经 沉浸 在 这 个 软件 中 了 。 疲惫 令 我 们 无 法 判断 什么 有 道理 或 是 直觉 上 
正确 ， 还 会 让 我 们 漏 掉 一 些 细节 。 

这 个 功能 应 该 放 在 这 儿 还 是 放 在 那儿 ? 这 个 函数 要 不 要 换 一 
屏 ? 这 人 么 做 有 道理 吗 ? 刚 做 的 调整 真 的 那么 重要 吗 ?9 到 下 午 五 点 时 
《对 于 那些 真正 工作 过 度 的 人 来 说 ,是 到 了 凌晨 两 点 时 ), 我 们 已 经 很 
难 判断 软件 给 人 的 感 党 了 ， 因 为 鼓 的 它 太 久 了 。 

然而 , 在 早上 九 点 , 一 觉醒 来 ,精神 焕发 我 们 常常 可 以 更 好 地 
回答 这 些 问 题 。 前 夜 一 团 乱 麻 的 思路 已 经 烟消云散 。 在 一 头 扎 进 代 码 
之 前 ， 这 是 再 度 审 视 软件 的 最 佳 时 机 。 

伴 着 朝阳 ,我 们 对 软件 又 有 了 新 的 感觉 对 它 的 看 法 也 不 会 受到 
瑟 人 台 实 现 的 髓 绊 。 因 为 已 经 离开 它 有 一 段 时 间 , 所 以 我 们 可 以 用 一 种 
更 公正 的 眼光 审视 它 。 

早晨 , 我 们 会 忘记 前 夜 困扰 我 们 的 繁复 的 代码 细节 ,也 不 会 纠缠 
于 某 个 功能 不 大 精彩 的 实现 , 我 们 会 全 心 投入 眼前 所 见 的 东西 ,而 不 
去 思考 它 背 后 发 生 的 事情 。 
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“这 些 是 我 在 你 桌子 里 找到 的 ……” 


测试 的 时 候 ， 从 头 开始 。 不 要 纠缠 于 某 个 部 分 ,重新 体验 一 遍 就 
对 了 。 前 夜 , 你 可 能 在 实现 一 个 功能 , 但 真正 的 用 户 可 能 只 会 使 用 它 
一 两 次 ,其 至 从 来 不 会 去 用 。 早晨 , 要 专注 于 那些 大 多 数 人 会 经 常 使 
用 的 功能 。 关 注 软件 中 的 优先 事项 ， 关 注 那 些 需 要 首先 修正 的 东西 ， 
这 种 方式 要 好 得 多 。 

在 编写 新 代码 之 前 ， 要 在 早晨 ， 即 你 最 清醒 的 时 候 先 做 测试 ， 这 
可 以 保证 你 一 直 在 开发 好 的 软件 。 
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20 世纪 90 年代 未 ， 我 就 开始 在 大 学 宿舍 里 面 建 网 站 了 。 到 了 大 
四 , 我 的 时 间 基 本 上 就 分 成 两 块 : 白天 上 几 节 课 来 凑 够 学 分 ， 晚 上 就 
在 宿舍 里 面 搞 自由 职 ， 设计 网 站 。 作 业 ? 什么 作业 ? 

当 有 些 同 龄 人 在 食堂 或 者 计算 机 实验 室 ( 还 记得 吗 ? ) 做 兼职 挣 
最 低 工资 的 时 候 , 我 却 穿着 短裤 坐 在 屏幕 前 ， 动 动 鼠标 就 能 拿 到 五 倍 
于 他 们 的 小 时 工资 。 我 离 床铺 只 有 一 步 之 遥 一 一 要 是 某 天 过 得 不 好 ， 
走 过 去 也 许 要 两 步 。 

有 上 段 时 间 ， 我 觉得 生活 就 该 这 样 了 。 我 一 边 拿 着 学 位 ,一 边 还 拿 
着 对 于 一 个 在 卧室 里 工作 的 大 学 生来 说 非常 可 观 的 薪水 。 

毕业 之 后 的 那个 秋天 ， 我 去 了 芝加哥 的 一 家 小 型 技术 公司 上 班 。 
当时 正好 赶 上 互联 网 泡沫 破灭 ,美国 经 济 一 落 干 丈 。 工 作 了 六 个 星期 
之 后 ， 我 的 职位 也 “破灭 ”了 ， 于 是 我 回去 和 父母 一 起 住 了 。 一 夜 之 
间 ， 作 为 一 个 22 岁 的 成 年 人 ， 我 又 在 舒适 的 卧室 里 做 起 了 自由 职 ， 
者 ， 接 了 几 个 网 页 设计 项 目 。 

头 几 个 星期 的 感觉 棒 极 了 , 但 起 初 的 蜜月 期 过 后 ,穿着 睡衣 工作 
就 觉得 有 点 别扭 了 。 毕 竟 我 不 是 在 学 校 了 , 朋友 们 也 不 在 我 楼 下 或 是 
校园 里 了 , 周围 就 只 有 我 和 我 的 电脑 。 由 于 没有 其 他 必须 参加 的 活动 ， 
比如 去 上 课 或 是 拿 学 位 ， 所 以 我 所 有 的 时 间 都 用 来 工作 了 。 

我 不 是 每 天 连续 挥汗如雨 八 个 小 时 , 而 是 一 天 到 晚 都 在 断断续续 


日 间 法 庭 电 视 节 目 ， 再 干 上 几 个 小 时 ， 之 后 跑 个 步 ， 吃 个 饭 一 一 工 ， 
对 了 一 一 晚上 还 要 再 干 几 个 小 时 。 就 这 样 , 原本 四 五 个 小 时 的 收费 工 
作 时 间 被 摊 到 十 二 至 十 四 个 小 时 里 。 我 的 工作 和 生活 混为一谈 , 工作 
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的 激情 和 效率 也 没 了 。 

正如 帕 金 森 定 律 所 说 :“ 工 作 会 不 断 膨 胀 ， 直 至 占 满 所 有 可 用 的 
时 间 之 后 才 会 完成 。 由 于 我 可 以 在 一 天 中 的 任何 时 间 “ 工 作 ”， 所 以 
可 占用 的 时 间 就 多 了 去 了 。 每 周 40 个 小 时 的 工作 突然 就 变 成 了 168 
小 时 的 工作 + 睡觉 + 吃喝 娱乐 。 
在 家 办 公 是 一 种 佬 侈 。 大 部 分 人 都 宁愿 在 家 办 公 ， 也 不 愿 花 两 个 
小 时 去 上 班 。 但 如 果 你 有 符 享 受 这 一 点 ,， 千 万 不 要 在 卧室 里 办 公 ， 最 
好 也 不 要 在 起 居室 。 搞 出 一 个 封闭 的 工作 区 ,最 好 是 单独 的 一 个 房间 ， 
这 样 就 可 以 在 工作 时 间 结 束 后 从 那里 离开 。 一 天 结束 之 后 关上 门 , FE 
上 一 个 “ 打 料 ”的 牌子 ， 然 后 去 享受 生活 中 的 其 他 乐趣 ， 第 二 天 再 继 
续 工 作 。 

这 才 是 真正 的 生活 。 
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对 软件 来 说 , 用 户 的 第 一 印象 到 底 有 多 重要 ?” 尤其 是 不 那么 好 的 
印象 ? 我 一 点 儿 也 不 觉得 第 一 印象 特别 重要 , 我 们 不 应 该 因为 不 好 的 
印象 而 让 自己 的 热情 瞬间 消退 

诚然 , 不 好 的 第 一 印象 可 能 是 个 信 言 号 ， 它 说 明 我 们 的 软件 确实 有 
什么 不 对 劲 。 但 我 发 现 ， 造 成 很 多 不 好 的 第 一 印象 的 原因 有 两 个 。 


一 印象 不 好 可 能 是 因为 不 熟悉 


有 时 候 , 第 一 印象 不 好 完全 是 因为 之 前 没 用 过 这 个 软件 。 对待 这 
种 印象 时 ,我 们 要 持 保留 态度 。 比 如 ,第 一 次 用 Gmail 的 时 候 ， 我 心 
想 : 


这 些 邮 件 就 像 小 型 论坛 一 样 , 像 讨 论 的 线索 一 样 …… 而 
不 像 电 子 邮 件 , 有 意思 , 也 有 点 怪 。 我 喜欢 吗 ? 不 怎么 喜欢 。 
还 行 。 我 也 不 知道 …… 也 许 吧 。 
Gmail 的 邮件 线索 在 最 开始 是 个 很 奇怪 的 概念 。 我 听 过 很 多 人 对 
它 赞 不 绝口 ， 但 也 有 同样 多 的 人 把 它 批 得 体 无 完 肤 。 可 几 个 月 之 后 ， 
我 完全 听 不 到 这 种 争论 了 。 今天 , 你 和 用 Gmail 的 人 之 间 的 谈话 更 可 
bE 是 这 样 的 : 
戴 红帽子 的 人 : 嗨 ， 哥们， 你 用 Gmail 吗 ? 
REFA: AH, 
RTA: 你 觉得 怎么 样 ? 
戴 蓝 帽子 的 人 : ae 最 近 有 点 慢 。 不 管 了 ， 我 们 去 喝 杯 啤 
酒吧 ! 
最 后 我 发 现 ， 两 种 电子 邮件 系统 对 我 来 说 都 不 错 ,， 对 上 面 那 两 位 


xb 
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来 说 也 不 错 , 对 世界 上 绝 大 多 数 人 来 说 都 不 错 。 过 了 一 阵子 , 我 们 就 
都 不 再 纠结 了 。 实 际 上 ， 现 在 我 同时 用 Outlook 和 Gmail。 我 也 知道 
很 多 人 同时 使 用 非 Gmail 的 邮件 客户 端 和 Gmail。 我 用 Outlook 的 时 
fe, 看 到 的 就 是 普通 的 老式 邮件 ; 用 Gmail 的 时 候 ， 看 到 的 是 “类 似 
于 论坛 的 邮件 形式 ”。 到 头 来 ， 两 种 感觉 都 挺 舒 服 的 。 


“我 是 接受 比较 慢 的 那 种 。 


我 承认 ， 重 塑像 电子 邮件 这 种 深入 人 心 的 应 用 模式 确实 需要 勇 
气 。 不 过 幸运 的 是 ,在 我 们 这 行 ， 这 种 风险 要 小 得 多 。 单 选 按钮 还 是 
下 拉 列 表 ? 每 一 页 都 有 搜索 框 还 是 只 有 一 页 有 ? 最 可 能 的 回答 是 ? 
都 行 ， 都 行 ,都 行 。 到 头 来 ， 只 要 我 们 习惯 于 一 遍 又 一 遍地 看 同一 个 
软件 , 很 大 的 可 能 是 , 不管 最 开始 有 多 人 么 不 喜欢 这 个 设计 ,最 后 都 会 
适应 。 

我 知道 那些 反对 者 正在 大 声 抗议 。 我 的 意思 真 的 是 用 户 应 该 适应 
软件 , 而 不 是 反 过 来 吗 ? 我 真 的 是 在 说 , 对 于 软件 的 第 一 反应 不 重要 
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四 ? 说 这 话 的 是 那个 写 了 Flash Application Design Solutions: The Flash 
Usability Handbook [CB06] 的 家 伙 吗 ?是 的 ! 

我 不 是 说 第 一 印象 毫 无 价值 , 但 第 一 次 见 到 某 个 东西 的 时 候 , 最 
初 的 反应 通常 不 过 是 对 不 熟悉 事物 的 反应 而 已 。 人 类 天 生 会 对 新 事物 
DPR. 但 是 , 作为 开发 人 员 , 我 们 常常 太 把 用 户 的 第 一 反应 当 回 
事 了 。 

第 一 印象 不 好 可 能 是 因为 关注 了 次 要 问题 

另 一 个 问题 是 这 样 的 : 有 时 候 , 不 好 的 第 一 印象 并 不 能 反映 出 真 
正 重要 的 问题 。 

WER Google 刚 开 张 ， 而 我 是 一 个 可 用 性 测试 员 ， 那 么 我 的 第 一 
印象 可 能 是 这 样 的 : 

口 “Google 搜索 ”按钮 应 该 和 “手气 不 错 ” 按 钮 调 个 位 置 ， 因 为 

我 提交 信息 的 时 候 习 惯 于 点 最 右边 的 按钮 , 而 且 一 般 我 会 真 的 
去 搜索 ， 而 不 是 磁 运 气 。 
口 我 不 明白 “手气 不 错 ” 到 底 是 干 嘛 的 , ATRE, MANE 
示 告 诉 我 点 了 以 后 会 发 生 什么 。 
口 我 找 “ 高 级 搜索 ”选项 可 找 了 一 阵子 。 哦 ， 那 个 高 级 搜索 页 面 


真 难 用 。 
口 底部 的 导航 链接 应 该 是 在 搜索 栏 上 面 , 因为 我 习惯 于 导航 栏 出 
现在 那里 。 


要 是 现在 再 问 我 ， 最 初 的 那些 疑虑 大 部 分 都 可 以 消除 了 。 我 已 经 
适应 了 搜索 按钮 的 位 置 。 用 了 几 次 “手气 不 错 ” 按 钮 之 后 ,我 现在 知 
道 它 无 非 是 直接 把 你 转 到 第 一 个 搜索 结果 。 高 级 搜索 功能 ”我 从 来 都 
不 用 , 所 以 管 它 好 用 不 好 用 呢 。 那 些 底部 的 链接 也 是 ,我 很 高 兴 它们 
是 在 搜索 框 下 面 而 不 是 上 面 。 
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第 一 印象 常常 是 不 准确 的 , 因为 我 们 不 知道 最 后 是 否 会 适应 这 个 
软件 。 最 开始 觉得 重要 的 东西 ， 比 如 高 级 搜索 功能 ,可 能 压根 儿 就 不 
重要 。 对 于 那些 和 我 们 的 习惯 稍 有 出 入 的 东西 ， 比 如 “搜索 ”和 “ 手 
气 不 错 ” 的 顺序 ， 过 一 阵子 就 适应 了 。 

所 以 ， 当 你 从 顾客 、 客 户 或 是 同事 那里 得 到 负面 反馈 的 时 候 ， 要 
坚持 自己 的 想法 ， 解 释 你 这 样 做 的 道理 ， 让 他 们 适应 你 的 作品 几 天 ， 
而 不 要 让 最 初 的 即时 反馈 打消 你 的 积极 性 。 

如 果 问 题 仍然 存在 ,那么 你 的 软件 可 能 确实 有 玻 钼 ,但 你 会 惊讶 
地 发 现 ， 很 多 最 初 的 负面 印象 通常 都 消失 了 。 
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第 15 篇 ”软件 发 行 的 情感 价值 


上 一 章 中 我 谈 到 了 发 行 。 在 如 今 的 开发 过 程 中 , 发行 无 非 是 软件 
生命 周期 中 众多 次 发 布 中 的 一 个 。 但 发 行 之 所 以 重要 还 有 男 一 个 原 
因 : 发 行 日 期 本 身 是 一 个 强大 的 动力 源 。 

为 喻 呢 ?” 因 为 我 们 知道 软件 不 青 是 在 局 外 等 等 了 ， 它 有 生命 了 ， 
准备 好 了 ， 这 对 自信 心 是 一 个 巨大 的 提升 。 

第 一 期 完工 带 来 的 美好 感觉 对 于 我 们 后 续 工作 的 效果 和 效率 有 


巨大 的 影响 。 想 想 无 穷 无 尽 地 调整 那些 还 没 能 内 亮 登场 的 软件 时 的 丧 
气 感觉 吧 。 


不 过 有 时 候 , 我 们 害怕 发 行 ,因为 发 行 就 意味 着 我 们 珍贵 的 软件 
要 任凭 公众 “摆布 ”了 。 他 们 会 怎么 说 呢 ? 就 像 上 一 篇 说 的 ,他们 最 
开始 说 的 可 能 并 不 是 日 后 他 们 所 想 的 。 即 使 必须 做 出 些 关 键 的 改变 ， 
我 们 也 做 得 到 。 很 少 有 功能 加 减 或 逻辑 调整 是 不 可 能 实现 的 。 好 的 程 
序 员 一 直 都 准备 着 干 这 个 呢 。 设 计 模 式 、 重 构 方 法 和 最 佳 实践 主要 都 
是 为 了 适应 未 来 修改 的 。 

所 以 ， 能 发 行 时 就 发 行 吧 。 下 一 章 谈 到 生产 率 的 时 候 ， 你 会 看 到 
保证 发 行 日 期 不 会 一 拖 再 拖 的 方法 。 
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第 16 篇 ” 找 个 争论 话题 


除了 去 写 下 一 个 伟大 软件 的 代码 ， 还 有 其 他 的 方法 来 保持 动力 。 
找 个 争论 话题 吧 。 找 一 个 你 无 比 赞同 的 话题 , 要 是 找 一 个 你 毫 不 
掩饰 地 反对 的 话题 就 更 好 了 , 然后 大 声 讲 出 来 , 细致 入 微 地 解释 为 什 
么 你 的 方法 行 得 通 。 
参加 一 个 当地 的 Meetup.com 讨论 组 ， 或 是 申请 在 会 议 上 发 言 。 
不 要 觉得 你 水 平 不 够 或 是 准备 不 足 ， 如 果 能 找到 一 个 热爱 的 话题 , 你 
就 已 经 准备 好 了 。 你 不 需要 是 一 个 拥有 五 万 名 微 博 粉 丝 的 技术 明星 ， 
也 不 必 是 来 自 一 个 超级 成 功 的 公司 的 编程 英雄 。 就 现在 而 言 ,你 只 要 
做 自己 就 好 了 。 网络 社区 的 好 处 就 在 于 , 你 的 发 言 权 首 先是 建立 在 内 
容 上 的 。 如 果 你 有 话 要 说 ， 人 们 会 想 听 的 。 
如 果 你 一 想到 发 言 就 手心 冒 汗 的 话 , 那 就 写 写 吧 。 写 作 让 你 有 机 
会 字 黄 句 酌 ， 让 它 至 于 完美 。 你 可 以 自己 建 个 博客 ,也 可 以 联系 其 他 
影响 力 的 博客 作者 ,， 写 上 一 些 客座 文章 。 你 会 惊讶 于 这 个 社区 有 多 
么 包容 。 
需要 争论 话题 ? 下 面 就 是 几 个 观点 两 极 化 的 话题 , 你 可 以 从 这 里 
Aas 
口 在 HTML 标记 中 ， 对 于 表格 内 容 之 外 的 东西 用 <TABLE /> 合 
适 吗 ? 很 多 标记 语言 纯净 论 者 说 “不 ”。 也 许 你 可 以 说 “是 ”， 
然后 解释 为 什么 。 
O 在 富 网 络 应 用 中 ，Adobe Flash 还 有 意义 四 ?或 者 ，HTML5、 
CSS3 和 JavaScript 的 进步 是 不 是 足以 淘汰 Flash? 
O 对 象 关系 映射 (ORM ) 比 原生 SQL 更 好 用 吗 ? 很 多 人 认为 
ORM 在 做 复杂 数据 库 查 询 时 通常 效率 低下 ， 其 他 人 则 认为 
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ORM 为 开发 人 员 提 供 的 简洁 性 足以 弥补 该 不 足 。 
口 模型 -视图 -控制 器 〈《MVC ) 架构 是 不 是 构建 所 有 应 用 软件 的 
最 佳 方法 呢 ? 有 些 人 说 这 个 架构 太 过 腾 肿 , 单单 使 用 标准 页 面 
模型 更 好 。 
口 可 用 性 测试 和 AB 测试 对 于 网 络 应 用 到 底 有 多 重要 ”有 人 说 
它们 言 过 其 实 , 对 应 用 进行 研究 所 付出 的 先期 成 本 和 时 间 是 不 
值得 的 。 
正如 本 章 所 说 , 动力 可 以 有 很 多 种 形式 。 它 不 一 定 只 局 限 在 代码 
里 , 它 还 可 以 是 我 们 离开 办 公 桌 时 看 待 工作 的 方式 , 甚至 一 个 好 的 争 
论 话题 也 可 以 让 我 们 热情 高 涨 。 

如 果 你 能 够 在 整个 开发 生涯 中 保持 动力 ， 那 么 你 的 效率 也 会 提 
高 。 让 我 们 来 看 看 如 何 把 动力 转化 为 持久 的 生产 力 吧 。 
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动力 可 能 是 起 步 时 所 需要 的 ,但 生产 力 才 是 衡量 成 功 的 具体 标 
准 。 本 章 讲 的 是 如 何 保持 干劲 ， 可 以 每 天 都 激情 饱满 地 工作 。 

在 企业 里 ,生产 力 和 其 他 任何 概念 一 样 ， 都 换算 成 某 种 可 以 计算 
的 指标 。 就 生产 力 而 言 ， 这 个 指标 就 是 利用 率 (utilization ) 或 者 产能 
(throughput )。 生 产 力 常 第 用 一 个 公式 来 表示 ， 计 算 我 们 做 了 多 少 工 
YE, 或 者 我 们 同时 在 应 付 几 件 事情 ,而 不 是 工作 的 质量 如 何 。 真正 的 
生产 力 其 实 应 该 关心 工作 的 质量 。 

比如 同时 处 理 多 项 任务 ,让 我 们 感觉 自己 似乎 很 高 效 , 但 这 
很 少 能 真正 把 工作 做 好 。“ 边 吃 午餐 边 工作 ”就 是 一 例 ， 一 只 手 
老 长 的 三 明治 , 另 一 只 手 用 一 个 手指 敲 键 盘 , 这 样 能 写 出 多 少 高 
的 代码 ? 

更 重要 的 是 , 这 么 干 实在 不 怎么 舒服 。 请 走出 办 公 室 ， 从 从 容 容 
地 吃 顿 午饭 ,然后 出 去 呼吸 呼吸 新 鲜 空气 。 等 你 回来 的 时 候 , 代码 就 
得 来 全 不 费 工夫 了 。 
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我 们 每 个 人 都 有 一 堆 消 闲 项 目 , 可 能 是 写 了 一 半 但 从 来 没完 成 的 
软件 ,也 可 能 是 开始 写 时 干劲 十 足 , 但 因 出 现 更 紧迫 的 事情 而 看 然而 
止 的 代码 。 可 以 怪 其 他 工作 占用 了 时 间 , 也 可 能 是 我 们 自己 已 然 失去 
兴趣 了 。 

这 类 消闲 项 目 本 身 没有 严格 的 时 间 限 制 , 而 且 不 成 功 也 没什么 关 
系 ， 因 此 注定 要 失败 。 如 果 它 的 发 行 日 期 不 定 ， 只 是 “未 来 某 年 某 月 
的 某 一 天 ”， 很 可 能 我 们 近期 就 不 会 去 完成 它 。 有 些 人 似乎 花 了 几 年 
时 间 来 琢磨 下 一 个 伟大 的 构思 , 却 没有 一 开始 就 明确 具体 要 花 多 少时 
间 来 实现 它 。 

三 个 月 怎么 样 ? Jack Dorsey 开发 了 一 个 鲜 为 人 知 的 短信 服务 , 他 
从 构思 到 发 布 第 一 版 所 花 的 时 间 还 不 到 三 个 月 , 这 个 服务 就 是 后 来 的 
推 特 。" 试 想 一 下 ， 如 果 他 年 复 一 年 地 开发 ， 而 不 是 一 旦 开始 就 闪电 
发 布 ， 那么 结果 可 能 就 大 不 一 样 了 。 


时 机 就 是 一 切 


由 此 可 见 ， 时 间 是 保持 编程 动力 的 最 重要 的 因素 。 对 于 消闲 项 目 
来 说 , 刚 开 始 写 代码 的 时 候 , 你 可 以 出 于 好 玩 或 者 学 习 的 目的 。 但 是 ， 
当 你 决定 认真 对 待 它 的 时 候 ， 就 需要 定 下 一 个 期 限 。 如 果 能 正确 处 理 
下 面 几 个 问题 ， 就 可 以 把 它 变 成 真正 的 项 目 。 

O 我 每 周 要 人 花 几 天 、 每 天 要 花 多 少时 间 在 这 个 项 目 上 ? 
O 我 什么 时 候 能 把 一 个 基本 成 型 的 产品 展示 给 别人 ? 


@D 参见 http://en.wikipedia.org/wiki/Twitter。 
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口 哪 一 天 向 公众 发 布 ? 
口 哪 一 天 发 布 第 一 个 主要 的 更 新 版 本 ? 

第 一 个 问题 设 定 了 可 持续 的 每 日 工作 量 。 可 能 只 是 一 天 两 小 时 、 
一 周三 天 , 但 必须 要 坚持 。 每 天 下 午 三 点 到 五 点 做 它 ， 比 说 什么 “有 
空 就 做 ”要 好 。 还 要 均匀 地 分 配 时 间 。 每 周一 、 三 、 五 做 它 可 能 比 周 
末 一 口气 连 做 三 天 要 好 , 否则 两 次 之 间 的 间隔 太 长 , 你 要 花 好 多 额外 
的 时 间 来 回顾 上 次 的 进度 。 最 后 ， 时 间 表 要 切实 可 行 。 一 旦 养 成 “ 今 
天 放 一 放 ， 明 天 再 补 上 ”的 习惯 ， 你 很 快 就 会 对 它 失 去 兴趣 。 

第 二 个 问题 为 可 供 测试 的 软件 设 定 了 一 个 期 限 。 这 就 像 在 地 上 打 
了 一 个 桩 : 不 和 久 后 的 某 个 时 间 , 我 们 的 同事 、 朋 友 或 是 爱人 就 能 看 一 
眼 我 们 的 成 果 。 这 可 以 帮助 我 们 倒 算出 ， 从 现在 到 那 时 , 一 共和 需要 多 
少时 间 来 完成 它 。 再 考虑 每 天 和 每 周 能 花 多 少时 间 , 我 们 就 能 知道 每 
次 要 写 多 久 代码 。 

第 三 个 问题 让 我 们 准备 好 一 个 “ 够 用 ”的 软件 ,在 大 的 方面 都 无 
碍 ,可 以 供 公众 使 用 。 它 随时 都 可 以 发 行 了 。 从 上 一 个 日 期 到 这 个 日 
期 之 间 的 这 段 时间 都 用 来 修复 关键 bug， 而 不 是 添加 成 百 上 千 个 小 功 
虽然 我 们 很 想 添 加 进去 , 但 几 个 星期 内 没有 这 些小 功能 的 话 也 


能 
无 妨 。 

最 后 该 考虑 第 四 个 问题 了 。 它 安排 了 发 行 之 后 的 一 切 。 软 件 已 经 
发 行 了 , 现在 需要 设 定 一 个 时 间 来 推动 新 的 发 布 。 新 的 发 布 可 能 在 发 
行 一 星期 之 后 或 更 早 ， 对 基于 Web 的 软件 ， 可 以 是 发 行 之 后 的 几 天 ， 
甚至 几 小 时 。 一旦 到 了 这 个 阶段 ,我 们 就 可 以 不 断 发 布 新 版 本 了 o 

这 些 时 间 限 制 就 像 建 起 了 围墙 , 我 们 要 用 工作 填 满 它 。 它 帮助 我 
们 确定 最 重要 的 功能 , 为 我 们 投入 软件 的 每 分 每 秒 提供 了 目的 。 如果 
没有 严格 的 时 间 限 制 , 我 们 可 以 磨 足 一 辈子 , 琢磨 着 是 不 是 万 无 一 失 
T o 我 们 不 是 为 交付 做 好 准备 , 而 是 每 一 步 都 精 雕 细 刻 , 调整 个 没完 。 
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失去 了 那 种 紧迫 感 ， 生 产 力 就 会 村 竭 。 时 间 限 制 敦促 我 们 前 进 。 
设 定 一 个 最 后 期 限 ， 即 使 是 随便 设 的 


我 们 公司 的 第 一 个 正式 产品 DoneDone”, 就 是 从 我 的 一 个 消闲 项 
目 发 展 起 来 的 。DoneDone 是 一 个 简单 的 基于 Web 的 bug 跟踪 工具 ， 
侧重 清晰 简洁 的 工作 流程 而 不 是 复杂 的 功能 。 我 最 开始 做 这 个 消闲 项 
H, 是 因为 不 喜欢 我 们 正在 使 用 的 那个 每 个 月 要 付 120 美 元 的 bug 跟 
踪 工 具 。 有 些 地 方 我 们 本 想 简 洁 ， 可 它 却 搞 得 花 里 胡 哨 ; 我 们 的 流程 
本 可 以 效率 更 高 , 可 它 偏偏 缺点 什么 。 我 知道 我 能 做 得 更 好 。 如 果 我 
们 愿意 花 钱 买 现 有 的 bug 跟踪 需 ， 别 人 也 肯定 愿意 花 钱 买 我 们 的 。 

开始 儿 个 星期 , 我 只 是 在 构思 ,没有 线 框图 也 没有 说 明 书 。 我 只 
是 写 代 码 、 做 界面 、 测 试 、 调 整 ， 然 后 再 继续 写 。 我 还 处 在 开发 蜜月 
期 ,虽然 没什么 方向 ， 但 一 想到 产品 能 挣 钱 就 干劲 十 足 。 

几 个 月 后 ， 到 十 一 月 时 ,客户 的 工作 又 开始 多 了 ， 自 然而 然 我 的 
消闲 项 目 被 排 到 了 后 面 。 每 隔 几 天 ， 我 就 抽出 几 个 小 时 来 做 
DoneDone， 但 效率 很 低 ， 因 为 大 部 分 时 间 都 花 在 重新 熟悉 前 面 所 做 
的 东西 上 。 由 于 时 间 是 零散 的 ， 所 以 突然 闲 下 来 的 时 候 , 很 难 决定 具 
体 应 该 做 什么 。 

所 以 ， 我 需要 一 种 新 的 方式 。 作 为 一 项 业务 ，DoneDone 需要 有 
客户 项 目 一 样 的 紧迫 程度 。 它 和 我 们 为 其 他 客户 所 做 的 项 目 有 何 区 别 
呢 ? 无 非 是 我 们 是 自己 的 客户 。 和 客户 项 目 一 样 , 我 们 也 需要 制定 几 
个 期 限 : 一 个 内 部 发 布 DoneDone 的 日 期 , 一 个 向 公众 发 布 产 品 的 日 
期 ， 以 及 后 续 发 布 更 新 版 本 的 日 期 。 

最 后 ， 我 决定 要 在 2009 年 4 月 15 日 发 布 DoneDone。 每 年 4 月 


D 参见 http://www.getdonedone.com。 
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15 日 也 是 美国 国税 局 征 税 的 日 子 ， 这 二 者 间 的 巧合 是 否 有 些 诗意 ? 
老实 讲 ， 这 完全 是 随便 挑 的 日 子 , 大概 还 有 六 个 月 ,感觉 是 个 合适 的 
时 间 一 一 剩 下 的 时 间 不 太 多 也 不 太 少 。 还 有 很 多 工作 要 做 , 但 如 果 我 
把 工作 日 50% 的 时 间 花 在 DoneDone 上 ,然后 时 不 时 找 几 个 人 来 帮忙 ， 
就 可 以 让 这 个 项 目 运转 起 来 。 一 个 消闲 项 目 就 这 样 突 然 变 成 了 真正 的 
项 目 。 

最 后 期 限定 好 ， 就 可 以 着 手 来 完成 必 不 可 少 的 工作 了 。 我 们 需要 
加 入 一 个 支付 网 关 , 确定 成 本 结构 ,构建 营销 网 站 ,然后 清理 功能 列 
表 。 所 有 的 事务 都 分 配 了 时 间 , 找到 了 位 置 。 这 种 紧迫 感 一 一 和 生产 
力 一 一 又 回来 了 。 

软件 发 行 之 后 ， 肯 定 还 有 其 他 的 功能 要 加 入 。 现 在 回 过 头 来 看 ， 
很 难 想象 如 果 没 有 这 些 功 能 DoneDone 会 怎样 不 堪 。 我 们 当时 没有 针 
对 问题 的 电子 邮件 -工作 单 系统 或 是 标签 系统 ， 这 两 个 都 是 当今 系统 
的 核心 组 件 , 但 在 发 行 时 它们 并 不 那么 关键 。 我 们 把 精力 放 在 一 个 花 
六 个 月 构建 的 bug 跟踪 工具 所 需 的 最 重要 的 功能 上 。 接 下 来 的 90 天 
内 ， 我 们 连续 发 布 了 十 个 更 新 版 本 。 

我 竟然 写 了 一 整 篇 文章 来 谈 最 后 期 限 吗 ? 还 真是 。 虽 然 它 一 点 都 
算 不 上 创新 , 但 制定 了 最 后 期 限 ， 工 作 才 得 以 完成 ,否则 产品 永远 难 
见 上 曙光。 最 后 期 限 提 升 了 工作 的 重要 性 。 如 果 让 一 个 项 目 从 几 个 月 拖 
到 几 年， 你 的 产品 可 能 就 失去 开始 时 所 期 待 的 价值 了 。 

最 后 期 限 创造 了 一 种 紧迫 感 ， 敦 促 你 冲 过 终点 线 。 即 使 没有 人 在 
通 迫 你 ， 它 也 能 给 你 所 需 的 鞭策 。 
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在 上 一 篇 文章 里 , 我 们 看 到 了 时 间 限 制 可 以 把 消闲 项 目 变 成 真实 
的 项 目 , 但 我 们 绝 不 是 只 能 够 限制 时 间 这 一 个 因素 。 所 有 软件 都 需要 
花 钱 来 做 ,所 以 还 可 以 为 成 本 设 一 个 上 限 。 成 本 上 限 赋 予 我 们 创造 力 ， 
它 可 以 帮助 我 们 更 有 效 地 利用 资源 。 

想 想 那些 彩票 启 家 的 悲惨 故事 吧 , 他 们 本 来 朝 九 晚 五 地 工作 ,可 
突然 有 了 一 大 笔 钱 ， 自 己 都 不 知道 该 怎么 花 。 他 们 没有 把 钱 存 起 来 ， 
而 是 肆意 挥霍 , 去 买 什 么 游艇 之 类 的 。 他 们 把 成 二 上 万 的 钞票 送 给 八 
笔 子 打 不 着 的 亲戚。 过 不 了 多 久 , 许多 人 就 会 债台高筑 , 日 子 过 得 比 
中 奖 前 还 要 惨 。 他 们 没有 意识 到 , 一 百 万 美元 仍然 是 有 限 的 。 BAE 
钱 上 的 限制 变 宽 了 ， 可 限制 还 是 存在 的 。 

同样 的 原因 导致 了 那么 多 风险 投资 支持 的 创业 公司 失败 。 在 最 初 
的 互联 网 泡沫 年 代 , 一 个 风 投 把 五 千 万 美元 扔 给 一 群 有 着 妹 渺 想法 却 
不 一 定 会 成 功 的 家 伙 , 简直 是 稀 松 平常 的 事 。 有 了 这 么 多 钱 ， 人 们 很 
容易 认为 下 一 步 就 是 在 市 中 心 租 个 宽敞 的 办 公 室 , 雇用 几 百 个 刚 毕 业 
的 大 学 生 ， 再 成 立 一 个 董事 会 。 毕 竟 ， 如 果 风 投 给 你 这 么 多 钱 ,， 你 最 
好 还 是 整 出 点 动静 。 

既然 市 场 对 未 经 检验 的 公司 估 值 如 此 之 高 , 想法 的 价值 ,而 不 是 
工作 的 价值 就 开始 膨胀 了 。 没 必要 先 弄 个 小 产品 出 来 , 放 到 市 场 里 看 
看 是 不 是 有 前 景 。 调 整 几 个 功能 、 重 新 部 署 软件 也 不 值得 再 加 上 一 百 
万 美元 。 有 些 公 司 不 是 根据 客户 的 数量 来 确定 Web 服务 带 的 容量 ， 
而 是 直接 先 买 下 整个 服务 器 集群 ， 然 后 坐等 客户 群 增长 。 
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“REK! 我 太 喜 欢 了 | 


取 之 不 尽 的 银行 金库 让 人 满 脑子 只 有 成 功 ， 而 没有 人 危机 感 。 很 
多 公司 也 貌似 找到 了 富有 生产 力 的 招数 ， 不 过 却 没 有 围绕 着 自己 的 
产品 。 

Kozmo.com 是 一 家 风 投 支持 的 公司 , 其 提供 的 服务 是 把 食品 和 娱 
乐 产品 送 上 门 ， 但 不 收 送 货 费 。 要 是 只 有 几 十 万 美元 来 运营 ， 它 也 许 
会 有 压力 早 一 点 儿 扭 亏 为 盘 。 可是, Kozmo.com 烧 掉 了 几 亿 美元 , 它 
把 毫 无 利润 的 业务 拓展 到 了 美国 九 个 主要 城市 。" 到 了 第 三 年 年 底 ， 
Kozmo.com 破产 清算 了 。 由 于 起 初 就 无 须 担 心 要 开发 一 个 能 启 利 的 
产品 , Kozmo 从 来 就 没有 机 会 把 一 个 有 前 景 的 想法 转化 成 实 实在 在 的 
产品 。 

如 果 没 有 限制 ， 无 论 是 时 间 限 制 、 成 本 限制 ， 还 是 功能 集 限制 ， 
我 们 就 会 忽略 现实 , 做 出 有 问题 的 决定 ,因为 没有 东西 敦促 我 们 做 出 
明智 的 选择 。 生 产 力 也 就 不 会 放 在 真正 重要 的 东西 上 。 

如 果 想 要 开发 伟大 的 软件 ,请 千 万 要 设 定 并 遵守 限制 。 让 你 走 的 
每 一 步 都 朝 着 创造 更 成 功 的 软件 的 方向 , 因为 没有 多 余 的 资源 去 做 其 
他 的 事情 。 


@ 参见 http:/moneycnn.comy/galleries/2010/Htechnology/1003/gallery.dot com busts/9.html。 
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第 19 篇 ”去掉 时 间 表 中 的 细节 


我 搞 软件 开发 十 二 年 了 , 从 来 没 见 过 一 个 项 目 是 完全 按 计划 走 的 。 

功能 会 变 ,未 预料 到 的 障碍 会 出 现 。 有 时 候 ， 我 们 预计 花 一 星期 
的 事情 最 后 花 了 三 个 星期 。 不 过 , 最 常见 的 事情 是 我 们 把 项 目 时 间 表 
制定 得 过 于 详细 。 给 每 个 小 部 件 都 设 一 个 最 后 交付 日 期 , 会 让 我 们 成 
为 时 间 表 的 奴隶 。 我们 在 一 步 还 没 走 的 时 候 , 就 决定 了 每 一 步 要 花 多 
长 时 间 。 其 实在 最 开始 的 时 候 ， 根 本 没 办 法 制定 出 一 个 完美 的 计划 。 

所 以 ,开始 做 计划 的 时 候 ， 要 少 计划 些 细节 。 

把 时 间 表 里 的 交付 成 果 分 成 几 个 可 以 伸缩 的 大 块 , 而 不 是 小 的 面 
包 丁 。 比方 说 你 是 在 规划 一 个 八 个 星期 的 项 目 , 那 就 找 出 八 个 每 周 要 
交付 的 成 果 , 而 不 是 四 十 个 每 天 要 交付 的 东西 。 不 要 为 软件 中 的 每 个 
交互 动作 设 定 交付 期 限 , 而 是 确定 何 时 完成 一 个 完整 的 部 分 。 说 到 底 ， 
时 间 总 量 是 一 样 的 ， 但 中 间 的 检查 点 要 少 一 些 。 

如 果 时 间 表 太 详 细 ， 交 付 太 频繁 , 开发 过 程 中 就 没有 做 试验 或 是 
重新 考虑 细节 的 余地 。 我 们 只 能 严格 遵守 根据 设想 出 来 的 任务 所 设 定 
的 时 间 表 ， 就 好 像 被 一 个 无 知 的 “微观 经 理 ” 一 直 监 督 着 一 样 。 要 是 
有 几 个 小 任务 没 按时 完成 ， 整个 时 间 表 就 青 然 淫 塌 了 。 这 一 点 也 不 会 
激发 我 们 的 积极 性 ， 好 的 软件 不 是 这 么 开发 出 来 的 。 

前 端 开发 人 员 处 理 屏 幕 设计 的 方法 可 谓 杀 异 。 有 些 人 喜欢 在 
Photoshop 里 面 做 好 一 个 完美 的 模拟 ， 然 后 再 把 效果 转化 为 HTML 和 
CSS; 有 些 人 喜欢 直接 上 手写 代码 ; 有 些 人 喜欢 先 专注 在 标记 的 结构 
E, 然后 再 加 入 个 别 的 颜色 或 者 调整 字体 大 小 ; 有 些 人 需要 一 边 搭 框 
架 一 边 设 计 ; 有 些 人 先 建 好 最 底层 的 公用 基础 ,然后 青 添 校 加 叶 ; 还 
有 些 人 则 是 先 为 最 优 的 屏幕 分 辨 率 设 计 好 ， 然 后 再 优雅 地 降级 。 
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为 完整 的 屏幕 设计 设 定 一 个 交付 日 期 是 一 个 不 错 的 里 程 碑 , 但 为 
所 有 的 中 间 部 件 〈 单 为 HTML 或 单 为 CSS ) 都 设 定期 限 可 不 大 好 ， 
因为 这 让 开发 人 员 失 去 了 自由 ， 无 法 选择 自己 最 高 效 的 工作 方式 。 
在 各 交付 物 之 间 留 出 合理 的 时 间 ， 以 便 我 们 施展 身手 。 可 以 把 一 
个 大 型 项 目 分 割 成 多 个 微型 项 目 , 但 我 们 仍然 有 机 会 以 自己 想 要 的 方 
式 来 进行 开发 。 这 也 让 我 们 可 以 在 下 次 交付 前 反复 雕琢 几 次 。 在 下 次 
交付 前 留 出 一 两 个 星期 , 也 就 允许 我 们 犯 几 次 错误 , 但 仍然 能 够 按时 


完成 。 
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第 20 篇 每 天 改进 产品 的 两 个 方面 


咱们 也 不 要 把 编程 说 得 太美 ， 因 为 我 们 时 不 时 就 觉得 开发 很 枯 
燥 。 有 些 时 候 我 就 想 干 点 别 的， 什么 都 行 ， 给 濒危 动物 作 开 胸 手术 
都 行 。 

在 编程 最 热火 朝天 的 日 子 , 我 们 只 能 从 那些 很 小 的 成 功 中 获得 持 
久 的 生产 力 。 写 代码 本 号 带 来 的 简单 满足 感 或 是 成 名 的 幻想 已 经 没 办 
法 一 直 激 励 我 们 了 。 每 天 都 得 有 那么 一 丁点 儿 灵 感 一 一 平常 的 动力 源 
RAST BE, CEPR o 

公司 成 立 的 第 一 年 , 我 花 了 好 多 时 间 来 做 一 个 基于 Web 的 数据 建 
模 应 用 ， 叫 做 X20。 直 至 今日 ，X20 仍然 为 我 们 在 We Are Mammoth 
所 做 的 每 一 个 Web 项目 建立 应 用 框架 。 它 生成 一 个 界面 来 建立 应 用 的 
数据 模型 ， 并 维护 数据 库 、 数 据 访问 层 和 Web 服务 , 这样 我 们 就 可 以 
很 快 地 开发 基于 数据 库 的 定制 应 用 。 

X20 是 一 个 有 着 宏伟 目标 的 应 用 。 它 有 些 地 方 复杂 得 让 人 发 疯 ， 
背后 需要 做 无 数 的 工作 。 拆 开 来 看 的 话 ， 它 综合 了 几 十 个 程序 ,生成 
定制 应 用 的 不 同 部 件 。 开 发 这 么 个 东西 又 要 保持 热情 不 是 那么 容易 
的 ， 因为 这 儿 十 个 程序 的 每 一 个 , 本身 就 都 是 很 大 的 软件 。 开 发 这 种 
大 家 伙 需 要 很 多 小 小 的 胜利 。 

当 我 深 陷 在 开发 中 时 , 我 为 X20 的 日 常 工 作 设 定 了 一 条 新 规则 : 
每 天 要 对 软件 作出 两 点 改进 。 

这 不 一 定 非 得 是 重大 的 改进 , 也 可 以 是 很 小 的 改进 ， 比 如 在 用 户 
界面 上 添加 更 优雅 、 更 友好 的 错误 信息 , 或 是 去 掉 废 代码 ， 即 便 是 保 
证 所 有 的 方法 都 有 很 好 的 注释 也 是 一 种 改进 。 有 时 候 , 我 一 天 能 处 理 
一 大 一 小 两 个 任务 ,有 时 候 我 可 能 就 处 理 两 个 小 的 任务 。 不 管 怎么 说 ， 
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每 天 我 都 知道 ， 当 天 的 X20 比 前 一 天 要 好 ， 而 且 这 种 进步 是 可 以 量 
化 的 。 

二 ”这 个 数字 本 和 映 也 很 重要 。 做 一 个 改进 有 时 候 让 人 为 难 ， 

为 我 们 不 知道 到 底 选 哪个 ; 而且 “一 ” 跟 “ 零 ”也 没有 多 大 差别 。 此 


外 ,“ 一 ”很 容易 让 我 们 觉得 ,今天 不 做 也 没什么 , 可 以 明天 再 补 上 。 
反 过 来 ， 每 天 做 “三 ”点 改进 又 太 多 了 。 所 以 ,“ 二 ” 才 是 那个 神奇 
的 数字 。 


决定 每 天 改进 产品 的 两 个 方面 是 一 个 很 好 的 想法 , 它 可 以 保证 大 
型 项 目 不 断 向 前 推进 。 一 周 下 来 ,你 的 产品 就 会 有 十 项 改进 ; 一 个 月 
下 来 ， 你 的 产品 就 有 四 十 项 改进 了 。 
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第 21 篇 为 良好 的 工作 环境 投资 


有 没有 注意 到 便宜 的 保鲜 膜 和 贵 的 保鲜 膜 之 间 的 区 别 ?” 对 于 节 
仿 的 人 来 说 , 为 一 卷 塑 料 膜 付出 双 倍 的 价钱 实在 不 值 , 但 两 种 保鲜 膜 
的 区 别 太 明显 了 : 好 的 保鲜 腊 拉 出 来 很 容易 ,而 且 它 不 太 会 自己 粘 成 
一 团 , SSH ARE He ed. 更 重要 的 是 , 好 的 膜 也 容易 据 下 来 。 

在 超市 里 , 我 们 倾向 于 选择 便宜 的 牌子 ,毕竟 只 是 保鲜 膜 而 已 嘛 。 
我 们 起 初 是 省 下 了 几 块 钱 ， 但 在 每 次 撕 下 那 片 拉 长 了 又 不 粘 的 塑料 
时 ， 都 要 郁闷 半天 。 

在 厨房 里 做 的 每 一 件 事 都 跟 撕 保鲜 膜 类 似 。 要 是 每 件 工具 都 不 那 
么 称 手 , 那么 训 饪 的 体验 就 会 充斥 着 一 个 个 效率 低下 的 环节 。 每 次 完 
成 工作 时 遇 到 的 小 障碍 越 多 ， 我 们 的 效率 就 越 低下 。 

同样 的 道理 对 我 们 程序 员 来 说 也 特别 适用 。 生产 力 依赖 于 我 们 工 
作 环 境 中 的 每 件 小 事 。 我 们 的 工作 环境 应 该 尽 可 能 减少 这 种 令 人 分 心 
的 事 。 


速度 快 、 功 能 多 的 机 器 会 物 有 所 值 


这 就 是 购买 好 的 硬件 至 关 重 要 的 原因 。 我 们 现在 付出 的 金钱 成 
本 ， 会 在 每 一 天 以 生产 力 的 形式 偿还 给 我 们 。 

我 最 近 从 一 台 用 了 七 年 的 运行 Windows XP 的 Dell Inspiron 9300 
笔记 本 ， 升 级 到 了 同时 运行 Windows 7 的 MacBook Pro。 这 可 是 一 笔 
不 小 的 投资 , 但 有 了 这 笔 一 次 性 的 投资 , 现在 我 工作 的 每 一 分 钟 都 在 
收获 它 带 来 的 好 处 。 

我 的 旧 笔 记 本 也 没什么 毛病 。 我 可 以 花 一 百 美 元 升级 一 下 内 存 ， 
然后 再 勉强 用 上 几 年 。 但 是 , 在 许多 细微 之 处 ， 它 就 和 那 卷 普通 的 保 
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鲜 膜 一 样 。 我 每 次 编程 的 时 候 都 要 付出 小 小 的 代价 。 
有 了 新 的 笔记 本 ， 我 现在 可 以 同时 使 用 两 种 平台 。 必 要 的 时 候 ， 
我 一 边 在 Mac 上 运行 快 得 多 的 Photoshop 版 本 ,一 边 在 Windows 上 用 
Visual Studio 做 .NET 程序 。 男 外 ， 我 还 可 以 同时 在 PC 和 Mac 上 做 浏 
览 絮 测试， 而 不 用 在 那些 淘汰 的 电脑 ( 很 多 公司 通常 标 为 “浏览 器 测 
试 机 ”) 上 装 好 多 个 浏览 器 。 


“还 是 没 反 应 。 你 确定 这 是 我 们 最 好 的 电脑 了 ? ” 


好 处 还 不 仅 限于 软件 。 我 甚至 爱 上 这 键盘 了 。 按 键 又 平 又 薄 ,， 触 
感 反应 刚刚 好 。 比 起 传统 的 笨重 键盘 , 我 打 起 字 来 更 流畅 顺 滑 了 ,， Æ 
错字 打 得 都 少 了 。 

想 想 每 次 不 打 错 字 意 味 着 什么 吧 。 这 意味 着 思路 被 少 打 断 了 一 
次 , 也 意味 着 不 必 将 目光 从 屏幕 转移 到 键盘 上 来 重 打 一 次 , 还 意味 着 
不 必 接 续 刚才 中 断 的 思路 。 

假设 有 了 新 键盘 ， 我 每 天 少 打 四 次 错字 ( 我 肯定 现实 中 要 比 四 
次 还 要 多 得 多 ), 那么 一 年 里 面 , 我 在 写 代 码 时 就 少 被 打 断 大 约 1000 
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次 ， 而 为 此 支付 的 成 本 不 过 是 一 个 新 键盘 。 
加 大 “地 产 ” 投 资 


在 厨房 里 , 台面 大 总 不 是 坏事 。 我 们 要 是 做 一 道 需要 几 十 种 原料 
的 菜 , 并 且 需 要 同时 使 用 几 个 大 器 具 , 那 么 有 一 大 请 地 方 就 太 重要 了 。 
这 样 我 们 就 不 用 把 东西 探 起 来 , 而 是 可 以 根据 自己 的 喜好 把 工具 放置 
在 不 同 的 地 方 。 

更 大 的 台面 ， 意 味 着 不 太 可 能 不 小 心 把 生 的 原料 放 在 熟 的 上 面 ， 
把 面粉 袋 掉 到 地 上 ， 或 是 因为 到 处 找 盐 而 把 鸡蛋 角 过 头 了 。 

在 编程 方面 ， 屏 幕 上 “地 产 ” 的 价值 也 是 这 样 。 要 是 只 有 一 个 显 
示 带 ,我 们 就 得 做 出 妥协 。 由 于 没有 足够 的 地 方 来 把 开发 环境 、 浏 览 
顺和 通信 工具 客户 端 同 时 “ 摊 在 台面 上 ”， 我 们 每 天 不 得 不 在 不 同 状 
态 之 间 切 换 一 干 次 。 

假设 我 们 想 在 测试 环境 中 严格 测试 代码 , 同时 在 浏览 器 中 运行 编 
译 好 的 应 用 。 要 是 屏幕 不 够 大 , 我 们 一 次 只 能 看 一 个 应 用 , 或 者 两 个 
应 用 都 缩小 到 细 细 的 横向 滚动 的 小 窗口 里 。 这 种 小 调整 实在 是 让 人 分 
神 ， 可 能 会 扰乱 我 们 的 思绪 。 

就 像 厨 房 台 面 一 样 ， 多 个 显示 器 能 大 大 提高 生产 力 。 

如 果 有 两 个 显示 器 ,把 开发 环境 摆 在 面前 ， 全 屏 显示 ， 必 一 个 显 
示 囊 上 则 一 直 开 着 测试 浏览 器 , 所 有 其 他 程序 ( 比如 邮件 和 聊天 客户 
Sig) 也 放 在 这 里 。 这 样 ， 你 就 可 以 一 直 专 注 于 开发 ， 并 且 在 另 一 块 显 
示 囊 上 做 测试 。 

要 是 有 三 个 显示 器 ,可 以 把 开发 环境 放 在 面前 ， 另 一 个 显示 需 开 
着 测试 浏览 器 ,然后 把 所 有 其 他 程序 ( 比如 邮件 和 聊天 客户 端 ) 放 在 
第 三 个 显示 融 上 。 如 果 你 想 要 全 神 贯 注 几 分 钟 , 不 想 让 闪烁 的 任务 条 
图 标 和 未 读 消 息 分 你 的 神 ， 只 要 暂时 把 第 三 个 显示 器 关 掉 就 行 了 。 


图 灵 社 区 会 员 cindy282694 专 享 尊重 版 权 


S218 为 良好 的 工作 环境 投资 


55 


说 个 题 外 话 ， 下 次 找 工 作 时 ,， 若 想 知 道 该 工作 好 不 好 ， 可 以 迅速 
扫 一 有 眼 办 公 室 , 就 知道 管理 层 是 不 是 关注 开发 团队 一 一 是 不 是 真正 关 


心 开发 人 员 的 工作 环境 。 数 数 房间 里 面 的 显示 器 , 然后 除 以 员工 人 数 。 


得 出 的 值 就 是 “关注 系数 ”。 


关注 系数 诊断 结果 

1 不 关注 

1~2 (不 包括 2 ) 有 一 定 程度 的 关注 

2~3 非常 关注 

大 于 3 你 进入 短线 操作 者 办 公 室 了 ， 马 上 走 人 吧 


工作 了 几 年 的 环境 可 能 现在 看 起 来 还 行 ,也许 你 已 经 习惯 了 , 但 
多 花 上 几 千 美元 可 不 光 是 一 笔 开 销 ， 而 是 对 生产 力 的 投资 。 
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第 22 篇 ， 列 一 张 个 人 待 办 事项 清 


有 时 候 , 最 简单 的 工具 可 以 让 生产 力 大 大 提高 。 列 一 张 个 人 待 办 
事项 清单 吧 。 

个 人 待 办 事项 清单 不 是 ( 我 再 重复 一 遍 ， 不 是 ) 像 项 目 时 间 表 或 
甘 特 图 那样 。 那 些 文档 都 是 给 团队 用 的 ,对 个 人 来 说 太 笼 统 了 。 它们 
都 是 反映 项 目的 大 局 ,而 不 是 指引 下 面 要 进行 的 几 步 。 当 然 ,它们 作 
为 “大 局 ”文档 很 有 用 ， 但 却 不 能 帮助 我 们 理 清 头绪 。 

个 人 竺 办 事项 清单 也 不 是 爆满 的 邮件 收 件 箱 。 用 电子 邮件 来 提醒 
自己 有 什么 事情 要 办 是 徒劳 的 。 电 子 邮 件 是 一 堆 零 碎 的 对 话 、 问 题 和 
未 区 分 优先 级 的 任务 的 大 杂烩 ， 而 不 是 一 张 现在 要 做 的 事 的 清晰 列 
表 。 电 子 邮 件 也 不 是 用 来 快速 浏览 的 。 

个 人 竺 办 事项 清单 只 是 一 张 检 查 单 ， 仅 此 而 已 快速、 简洁 ， 而 
且 有 效 。 

当 邮 件 里 收 到 一 个 任务 的 时 候 ， 请 把 它 记 在 个 人 竺 办 事项 清单 

里 。 如 果 加 入 了 一 个 必须 具备 的 功能 ， 把 这 个 功能 拆 分 成 小 的 事项 ， 
加 入 待 办 事项 清单 。 
ERER, 个 人 竺 办 事项 清单 无 非 是 又 一 个 要 维护 的 东西 ， 里 面 
所 有 的 事项 很 可 能 都 来 自 于 其 他 的 文档 。 这 似乎 是 个 不 好 的 做 法 , 因 
为 它 违背 了 大 多 数 人 在 写 代码 时 遵照 的 “不 要 重复 ”的 和 能 言 。 然 而 ， 
个 人 待 办 事项 清单 是 少数 可 以 接受 重复 的 例外 , 这 是 因为 , 它 的 作用 
和 其 他 更 为 严谨 的 文档 不 同 。 

和 其 他 文档 不 同 , 等 办 事项 清单 是 随时 可 以 调整 的 ， 从 来 都 不 是 
一 成 不 变 的 。 竺 办 事项 可 以 每 天 添加 、 勾 掉 、 推 迟 、 提 前 或 是 删 掉 。 
竺 办 事项 清单 与 项 目 时 间 表 和 甘 特 图 不 同 , 它 不 关心 过 去 , 它 的 起 始 
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点 永远 是 现在 。 它 列 的 也 不 是 猜测 的 任务 ， 而 全 是 井井有条 的 、 真 实 
的 、 必 须 在 近期 完成 的 任务 。 


好 的 个 人 待 办 事项 清单 的 内 容 


程序 员 的 个 人 待 办 事项 清单 应 当 具 有 下 列 特 质 : 
口 它 是 一 张 清 单 ， 且 只 有 一 张 清单 。 
口 它 有 四 个 栏目 ， 即 今天 、 明 天 、 后 天 和 未 来 。 
口 它 没有 山 套 的 依赖 关系 。 每 个 待 办 事项 都 直接 属于 上 述 一 个 
栏目 。 
口 容易 修改 。 可 以 很 容易 地 把 事项 挪 上 挪 下 。 
口 由 者 干 个 短 任务 构成 , 在 几 个 小 时 之 内 就 可 以 完成 。 未 来 一 栏 
中 的 项 目 可 以 更 宽泛 一 点 ， 我 们 后 面 会 谈 到 。 
D 在 线 。 不 管 在 哪儿 工作 都 能 看 到 。 

我 自己 使 用 37signals 的 Ta-da List 软件 ， 因 为 它 简洁 又 免费 。 下 
面 就 是 用 Ta-da List 创建 个 人 待 办 事项 清单 的 步 又 。 

创建 一 个 新 清单 ， 然 后 加 入 四 个 分 割 项 目 。 因 为 你 不 能 在 Ta-da 
List 里 面 建立 分 隔 符 , 所 以 只 要 放 进 四 个 永远 不 会 色 掉 的 待 办 事项 就 
行 了 。 事 项 前 后 加 上 短 划 线 ， 这 样 容易 和 其 他 真正 的 竺 办 事项 区 分 
开 来 。 


我 的 个 人 待 办 事项 清 i 
回 --- 今 天 --- 
回 --- 明 天 --- 
回 -- -后 天 --: 


日 -- -未 来 -- - 
添加 项 


在 添加 待 办 事项 时 ， 把 它们 放 在 合适 的 分 隔 符 下 。 如 果 一 件 事 你 
必须 今天 完成 ， 就 把 它 拖 到 今天 下 面 。 如 果 是 需要 明天 处 理 的 事情 ， 
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就 把 它 拖 到 明天 下 面 。 如 果 需 要 后 天 完成 ,就 放 到 后 天 下 面 。 如果 你 
也 不 知道 具体 要 什么 时 候 完 成 , 但 是 知道 很 快 会 有 一 个 任务 要 来 , 就 
把 它 放 在 未 来 下 面 。 

因为 待 办 事项 清单 中 没有 什么 是 定 死 的 , 所 以 如 果 你 不 确定 应 该 
归 在 明天 还 是 后 天 , 那 就 选 明 天 。 如 果 到 明天 结束 , 它 还 没有 成 为 最 
紧急 的 事情 ， 那 就 可 以 再 推 一 天 。 


把 功能 拆 分 成 待 办 事项 


你 放 进 “今天 ““ 明 天 ”和 “后 天 ”的 所 有 竺 办 事项 都 应 该 是 小 
的 任务 〈 几 个 小 时 就 可 以 完成 的 )。 比如， 制作 注册 和 登录 就 是 一 个 
不 好 的 待 办 事项 , 因为 要 过 好 长 时 间 你 才能 在 待 办 事项 清单 中 看 到 进 
展 。 制 作 注册 和 登录 可 以 分 解 成 一 系列 小 任务 。 


我 的 个 人 待 办 事项 清 
口 --- 今 天 --- 

口 注册 : fE HTML R 

口 注 册 : 实现 JS 验证 

口 注册 : 验证 电子 邮件 唯一 性 
口 注册 : 发 送 验证 邮件 


“忘记 密码 ”表单 
“忘记 密码 ”邮件 
“ 重 置 密码 ”表单 
“ 重 置 密码 ”确认 


O 未 来 将 要 做 的 事 …… 
添加 项 目 
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这 样 ， 我 们 就 把 制作 注册 组 件 拆 分 成 了 一 个 历时 三 天 完成 、 由 十 
项 任务 构成 的 待 办 清单 ， 并 并 有 条 ， 却 不 太 复杂 。 

每 个 待 办 事项 都 是 一 小 块 工作 。 一 旦 我 们 完成 了 一 件 事 , 就 可 以 
把 它 勾 掉 。 这 样 我 们 每 完成 一 件 事 时 ,就 会 立刻 有 一 种 满足 感 。 而 且 
也 不 用 等 待 完成 整个 组 件 ， 随 时 都 可 以 看 到 进展 。 

到 一 天 结束 时 ,我 们 可 能 没有 完成 所 有 计划 的 项 目 ,常常 会 剩 下 
一 两 项 。 太 阳 落 山 时 ,我 们 的 待 办 事项 清单 常常 看 起 来 是 下 面 这 个 样 
子 ， 今 天 还 剩 下 几 项 没有 完成。 

我 的 个 人 待 办 事项 清音 


口 --- 今 天 --- 
器 注册 : 发 送 验证 邮件 
口 --- 明 天 


口 登录 : 制作 登录 表单 
O 登录 : 实现 JS 验证 
天 


1 
To 
1 


TH TH TH TH 


“忘记 密码 ”表单 
E “忘记 密码 ”邮件 


oO 
BS ss SS 


y aaa 


X 


C 


X 


C 


O 未 来 将 要 做 的 事 …… 
添加 项 目 

ME: 验证 电子 邮件 唯一 性 

ME: 实现 JS 验证 


Et: 制作 HTML 表单 


明天 如 何 变 成 今天 


那 到 了 明天 要 怎么 样 呢 ? 昨天 要 是 剩 下 一 两 项 没 做 完 怎 么 办 ? 
只 要 几 秒 钟 ， 就 可 以 更 新 待 办 事项 清单 。 在 Ta-da List 里 面 ， 只 要 用 
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鼠标 拖 动 两 下 即 可 。 

首先 ,把 明天 分 隔 符 拖 到 后 天 分 隔 符 上 面 , 这 样 所 有 为 明天 设 定 
的 内 容 现 在 都 归 到 今天 了 ， 我 们 昨天 没有 完成 的 事项 还 留 在 今天 里 。 
再 把 后 天 拖 到 未 来 分 隔 符 上 面 , 这 样 所 有 为 两 天 之 后 设 定 的 内 容 都 归 
到 明天 了 。 


我 的 个 人 待 办 事项 清单 
图 --- 今 天 --- 

口 注册: 发 送 验证 邮件 
ORR: 制作 登录 表单 
ORR: 实现 JS 验证 


口 登录 : 制作 “忘记 密码 ”表单 
E “忘记 密码 ”邮件 
制作 “ 重 置 密码 ”表单 
eae: 制作 “ 重 置 密码 ”确认 


O 未 来 将 要 做 的 事 ……: 
添加 项 目 


4 注册 : 验证 电子 邮件 唯一 性 
Bite: 实现 JS 验证 
A 注册 : 制作 HTML 表单 


回 到 未 来 


每 天 都 要 看 一 眼 越 来 越 长 的 未 来 清单 。 如 果 你 需要 在 未 来 两 天 内 
完成 其 中 一 项 ， 把 这 个 任务 拆 分 成 小 块 ， 然 后 把 它们 安排 好 。 


每 天 重新 评估 重要 事项 
个 人 待 办 事项 清单 可 以 非常 完美 地 调整 优先 级 , 它 每 天 随 着 软件 
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开发 的 不 确定 性 而 变化 。 可 能 有 某 件 事 本 来 是 要 在 今天 完成 的 , 但 现 
在 看 起 来 不 那么 重要 了 ,只 要 把 它 拖 到 明天 甚至 更 远 就 可 以 了 。 类 似 
地 , 本 来 安排 在 后 天 的 事项 可 能 你 今天 有 精力 做 了 , 那 就 拖 动 , 完成 ， 
然后 把 它 勾 掉 。 

很 多 时 候 , 我 们 没 法 完成 今天 的 所 有 事项 ,可 能 有 一 个 事项 卡 在 
今天 有 好 多 天 了 ， 因 为 总 有 其 他 优先 事项 挡 在 它 前 面 。 

但 过 一 阵子 就 会 开始 浮现 出 模式 。 有 些 待 办 事项 一 直 在 今天 一 栏 
中 晃 修 ,或 是 经 常 被 推迟 到 明和 天。 这些“ 坏蛋 ” 待 办 事项 可 能 并 没有 
我 们 最 初 添 加 时 所 想 的 那么 重要 。 如 果 一 个 待 办 事项 已 经 晃 修 了 一 两 
个 礼拜 ,就 直接 删 掉 好 了 。 避免 不 重要 的 工作 和 完成 重要 的 工作 一 样 
富有 成 效 。 


啊 ， 怪 不 得 ! 它 在 我 的 “不 要 做 ”清单 上 ! 


个 人 待 办 事项 清单 不 是 什么 黑 魔 术 ， 它 不 会 替 我 们 把 工作 做 完 。 
不 过 , 它 能 帮助 我 们 理 清 头绪 并 即时 做 出 调整 ,还 能 让 我 们 每 天 都 看 
到 真正 的 进展 。 我 们 对 每 天 的 小 小 进展 感到 欣慰 ,这 让 我 们 明天 还 能 
保持 干劲 。 
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你 只 有 在 有 时 间 高 效 工作 时 , 才能 有 效率 。 说 起 来 容易 做 起 来 难 ， 
日 常 工作 中 的 那些 基本 活动 一 一 开会 , 打 电 话 , 同事 交流 一 一 实在 太 
普遍 了 ， 我 们 其 至 忘 了 这 些 实际 上 都 会 分 散 精 力 。 

那 其 他 公司 是 怎么 解决 分 神 问题 的 呢 ? 

37signals 宣传 一 种 远离 其 员工 的 哲学 。 在 《 重 来 》( Rework )[FH10] 
一 书 中 ,他 们 谈 到 , 干扰 不 仅 打 断 了 我 们 手头 正在 做 的 事情 ,还 让 我 
们 脱离 了 自然 的 “独处 空间 ”， 就 是 那 种 完全 专注 在 工作 上 的 状态 。 

Google 的 “20% 法 则 ”很 有 名 ， 它 允许 工程 师 每 周 拿 出 一 天 ， 专 
门 做 自己 特别 喜欢 的 一 个 和 公司 相关 的 项 目 。" 这 些 额 外 项 目 中 ,很 
多 最 后 都 变 成 了 Google 最 出 名 的 产品 ， 比 如 Google 新 闻 和 Gmail, 

那些 希望 员工 发 展 而 不 仅仅 是 生存 的 公司 , 都 需要 采取 一 些 方法 
来 将 其 变 成 现实 。 

如 果 可 以 选择 的 话 , 我 宁可 每 天 都 在 家 办 公 。 这 样 就 不 用 担心 客 
户 会 突然 打 来 电话 , 或 者 某 人 需要 我 马上 前 去 帮忙 ,没有 了 这 种 烦 扰 
简直 是 如 释 重负 ， 我 可 以 成 天 都 专注 在 代码 上 。 

但 我 们 也 要 为 客户 提供 服务 ， 有 时 候 这 需要 花费 很 多 精力 。 我 们 
很 难 整 天 都 在 编程 ， 总 有 火 要 救 ， 有 客户 要 联系 ， 有 邮件 要 回 。 


免 打 扰 时 间 ， 欢 迎 你 


几 年 前 , 我 在 公司 里 设置 了 免 打 扰 时 间 。 这 是 模仿 其 他 一 些 公司 
的 “ 别 来 打 偏 ， 让 我 干 活 ”的 规则 ， 同 时 仍然 满足 了 客户 的 需求 (如 


D 参见 http://www.nytimes.com/2007/10/21/jobs/21pre.html。 
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电话 、 邮 件 和 一 般 的 关注 )。 具体 做 法 如 下 。 

每 个 程序 员 每 天 轮流 有 两 个 小 时 的 免 打 扰 时 间 。 如 果 你 处 于 免 打 
扰 时 间 中 ， 那 么 
O 不 用 回 邮 件 。 
口 不 会 参加 会 议 。 你 在 这 段 时 间 中 没 空 。 
口 不 接 电 话 。 
口 同事 不 会 给 你 发 即时 消息 。 
O 同事 不 会 和 你 说 话 。 
在 免 打 扰 时 间 里 ,我们 在 桌子 上 竖 一 个 白旗 。 两 个 小 时 之 后 , 我 
们 回 过 头 来 查收 邮件 ,回复 电话 和 即时 消息 ,然后 照常 工作 。 这 条 黄 
金 法 则 很 简单 : 某 人 处 在 免 打 扰 时 间 时 ， 不 要 去 打扰 他 。 

要 是 全 公司 一 起 免 打扰 就 好 了 ， 但 这 对 于 我 们 的 业务 来 说 不 现 
实 。 这 意味 着 切断 与 所 有 客户 的 通讯 以 及 内 部 通讯 两 小 时 。 对 于 某 些 
客户 来 说 这 个 时 间 太 长 了 ， 特 别 是 我 们 正 处 于 发 布 中 间 的 时 候 。 

我 们 制定 了 轮流 免 打 扰 机 制 ， 例 如 : 
口 第 一 班 ， 每 天 早 10 点 到 中 午 一 一 Ka Wai, Michael 
口 第 二 班 ， 每 天 下 午 2 点 到 4 点 一 一 Anthony，Mustafa 
口 第 三 班 每 天 下 午 4 点 到 6 点 

因为 时 间 是 错开 的 ， 所 以 任何 时 候 只 有 一 两 个 人 处 于 免 打 扰 时 
间 。 公 司 不 会 一 下 子 就 切断 客户 联系 ， 大 部 分 时 候 都 可 以 联系 我 们 。 
别人 能 帮 你 

对 于 我 们 来 说 , 谁 进入 免 打 扰 时 间 不 是 随便 安排 的 。 我 们 在 每 个 
免 打 扰 时 间 段 内 ,都 把 不 同 职务 的 成 员 搭 配 起 来 .通常 ,我 和 Mustafa, 
Tom 和 Mike，Anthony 和 Craig 工作 联系 最 密切 ， 所 以 我 们 不 会 同时 
进入 免 打扰 时 间 。 


Tom, Craig 
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这 意味 着 如 果 有 紧急 情况 ， 搭 档 可 以 处 理 。 如 果 Craig 在 早上 
11:30 要 问 我 一 个 问题 , 他 可 以 去 问 Mustafa. 如 果 我 在 下 午 4:30 有 问 
题 要 问 Tom， 我 也 可 以 问 Michael。 如 果 客 户 在 某 人 的 免 打 扰 时 间 安 
排 了 电话 会 议 ， 他 的 搭档 就 可 以 在 这 个 时 间 代 替 他 。 


打扰 别人 是 最 后 选择 


由 于 免 打 扰 时 间 让 我 们 无 法 和 这 个 人 联系 ,这 会 让 每 个 人 都 更 认 
真 地 思考 自己 的 问题 ， 我 们 更 可 能 问 自 己 :“ 这 个 问题 我 能 不 能 
Google 一 下 就 解决 而 不 用 去 打扰 别人 呢 ? ”打扰 别人 是 迫不得已 的 
办 法 。 

免 打 扰 时 间 每 周 为 我 们 每 个 人 创造 了 没有 干扰 的 十 个 小 时 , 却 几 
乎 没有 影响 与 客户 和 内 部 的 联系 。 这 是 现实 中 保持 生产 率 的 好 方法 。 

所 以 , 无 论 只 是 几 小 时 的 免 打 扰 时 间 , 还 是 一 整 天 做 自己 事情 的 
自由 时 间 , 或 者 是 在 物理 上 相互 远离 ,实质 上 都 是 认真 考虑 一 下 ， 如 
何 可 以 互 不 打扰 ， 让 自己 更 为 高 效 。 
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很 多 大 公司 都 在 兜售 “人 是 我 们 最 宝贵 的 资产 ”的 陈 词 滥 调 ， 听 
起 来 就 恶心 。 这些 公司 同时 在 用 胸 牌 编号 来 标识 员工 , 用 发 购物 卡 的 
方式 来 挽救 员工 迅速 消退 的 积极 性 ,结果 呢 , 还 不 是 人 员 流 动 率 居 高 
不 下 。 不 过 ， 这 也 没 啥 大 不 了 。 

有 些 公司 ,特别 是 非常 大 的 公司 ,可 以 不 停 地 招聘 ,用 一 批 人 来 
补 男 一 批 人 ,以 保证 公司 持续 运转 。 他 们 可 以 继续 和 其 他 的 大 公司 签 
订 巨 额 合同 , 在 一 年 内 就 把 新 员工 青春 洋溢 的 活力 挤 得 干 干净 净 。 一 
且 榨 干 了 ， 就 又 去 市 场 上 找 人 。 雇 人 越 多 ， 补 人 越 多 ,“ 还 过 得 去 ” 
的 工作 职位 也 就 越 多 ， 公 司 就 这 样 维持 着 。 

我 们 常常 认为 这 是 “大 公司 ”导致 的 企业 现象 。 繁 文 丝 节 ， 官 条 
作风 ， 开 会 无 体 ， 优 柔 寡 断 ， 犹 殉 不 决 。 然 而 与 此 同时 ， 他 们 依然 高 
举 那 条 公司 格言 : 人 是 我 们 最 宝贵 的 资产 。 

说 老实 话 ， 在 我 的 小 咨询 公司 里 ， 人 不 是 最 宝贵 的 资产 。 我 非常 
WE, AVES ) 比 我 更 优秀 的 程序 员 、 设 计 师 、 思 想 家 和 作家 。 没 
有 谁 是 一 行 中 最 优秀 的 ， 总 是 人 外 有 人 。 

但 造就 我 们 较 高 生产 力 的 是 随 着 时 间 建 立 起 来 的 工作 关系 。 我 已 
经 和 几乎 同一 批 志趣 相投 的 人 一 起 工作 了 许多 年 , 这 种 团队 内 部 的 亲 
密 感 意味 着 我 们 知道 每 个 人 喜欢 的 工作 方式 。 

有 些 人 喜欢 细致 周到 地 工作 ， 每 一 行 代码 都 深思 熟 虑 ; 有 些 人 则 
是 粗 校 大 时, 再 事后 清理 ; 有 些 人 经 常 需 要 独自 工作 ,单枪匹马 解决 
问题 ; 而 有 些 人 则 一 上 来 就 需要 协作 。 慢 慢 地 ， 我 们 会 以 不 同 的 方式 
相互 弥补 ， 我 们 会 适应 周围 的 人 。 随 着 时 间 的 推移 ， 我 们 开始 凝聚 在 
一 起 ， 真 的 是 “ 凝 ” 在 一 起 。 
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与 此 同时 , 这 种 熟悉 让 我 们 在 辩论 的 时 候 无 需 担 心 伤 害 对 方 的 感 
情 。 在 一 条 战壕 里 战斗 多 年 的 战友 , 没 必要 再 去 相互 试探 想法 。 我们 
可 以 就 一 个 自己 赞同 的 想法 争 得 面红耳赤 , 不 用 小 心 惨 惨 地 担心 伤害 
对 方 的 感情 。 我们 开会 时 会 非常 地 活跃、 投入 ， 有 时候 争论 会 几 近 白 
Bub. 我 们 要 把 问题 捍 顺 ,找到 解决 方案 。 和 普通 公司 那 种 充满 了 问 
题 和 模棱两可 回答 的 会 议 比比 吧 。 在 那 种 会 议 里 , 避免 冲突 似乎 比 找 
到 最 好 的 答案 还 要 重要 。 

这 也 就 是 为 什么 我 说 , 程序 员 最 好 的 工作 环境 是 人 员 流 动 率 很 低 
的 自治 小 团队 。 在 大 公司 你 也 可 以 找到 这 样 的 团队 , 但 小 公司 里 更 常 
见 。 在 如 今 的 环境 下 ,小 公司 才能 经 党 冒 出 大 作品 ， 因 为 他 们 可 以 更 
快 地 决策 、 研 究 和 学 习 ， FFA BOAR OCI eee, 进而 可 以 更 快 地 

开发 。 想 想 那 些 被 许多 人 使 用 的 、 非 常 成 功 的 ， 却 由 很 小 的 公司 开发 

的 软件 吧 。 下 面 只 是 其 中 几 个 例子 。 
Q Campaign Monitor: 给 Web 设计 师 用 的 邮件 营销 软件 
O Litmus: 邮件 预览 监控 
D GitHub: 软件 开发 项 目 用 的 版 本 控制 库 
O Braintree: SaaS 服务 用 的 在 线 支付 网 关 
口 Basecamp: 项 目 管理 和 协作 软件 
口 愤怒 的 小 鸟 : 移动 益 智 类 视频 游戏 

这 种 相互 熟悉 性 最 终 把 一 群 优秀 的 个 人 变 成 了 一 个 生产 非常 出 
色 的 产品 的 伟大 团队 。 
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在 高 效 的 团队 开发 中 ， 明 确 责任 很 重要 。 是 的 ,知道 谁 负责 哪 一 
块 很 关键 , 但 知道 谁 不 对 那 一 块 负责 也 很 重要 , 他 们 有 其 他 的 责任 要 
承担 。 

当 你 和 同事 或 客户 沟通 的 时 候 , 特别 是 开会 和 写 邮件 的 时 候 , BC 
掉 那 种 说 “我 们 ”的 习惯 ,要 明确 地 说 出 “ 谁 ”。 

下 次 开 技 术 会 议 的 时 候 ， 留 意 一 下 你 讲 了 多 少 次 “我 们 ”。 你 说 
“我 们 ”的 时 候 ， 真 正 的 意思 可 能 是 “我 们 中 的 某 些 人 ”、“ 我 们 中 的 
几 个 人 ”, 或 者 很 多 时 候 只 是 你 自己 (或 是 John RÆ Mary ) 你 的 “我 
们 ”很 少 是 指 全 体 所 有 人 。 


“好 ， 既 然 我 们 都 同意 了 ， 就 回 到 座位 上 讨论 一 下 为 什么 这 个 不 行 。 


但 “我 们 ”这 个 词 给 人 的 印象 就 是 这 个 样子 。“ 我 们 ”一 下 子 毫 
无 必要 地 把 责任 扔 到 了 每 个 人 身上 , 它 不 去 区 分 真正 需要 操心 的 人 和 
需要 专注 其 他 工作 的 人 。 更 重要 的 是 , 它 掩藏 了 需要 提供 反馈 时 ,你 
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比如 ， 你 正在 写 一 个 工具 ， 用 来 把 遗留 数据 库 中 的 数据 转 出 来 ， 
你 需要 知道 Customers 表 是 归 哪 个 schema, 但 这 问题 你 不 需要 问 整个 
公司 。 前 端 设 计 师 很 可 能 不 知道 或 者 不 关心 。 即 使 数据 库 是 一 个 团队 
在 管 , 也 应 找 出 那个 真正 能 给 你 想 要 的 东西 的 人 。 不 要 说 我 们 需要 找 
到 这 个 schema， 而 要 说 具体 谁 应 该 给 你 提供 这 个 信息 。 

如 果 你 不 知道 应 该 找 谁 ， 随 便 挑 一 个 人 。 他 要 人 么 会 给 你 需要 的 答 
R, 要 么 会 把 责任 转交 给 正确 的 人 。 明确 责任 就 可 以 直接 把 事情 向 一 
个 方向 推动 : 前 方 。 

这 正好 和 “我 们 ”这 种 思维 模式 的 结果 不 同 。“ 我 们 ”这 个 说 法 
会 让 15 个 人 一 起 听 一 通电 话 , 会 将 同一 封 邮件 抄 送 给 12 个 人 , 或 让 
一 梨子 人 记录 着 他 们 不 理解 或 者 对 他 们 不 重要 的 事情 。 "我们 ”造成 
了 一 大 群 人 参与 谈话 ， 而 实际 上 只 有 少数 几 个 人 真 的 知道 在 说 什么 。 
“我 们 ”让 事情 的 噪声 呈 指 数 级 上 升 。 

“我 们 ” 带 来 噪声 

问题 是 ,“ 我 们 ”不 仅 会 产生 噪声 ， 还 会 让 噪声 成 倍 放 大 。 如 果 
你 把 “我 们 ” 带 到 了 谈话 中 ， 就 是 在 让 谈话 变 得 越 来 越 拖 省 见长 。 

为 什么 ? 因为 “我 们 ”让 你 问 出 一 些 没 必要 马上 回答 的 问题 ， 这 
些 问题 经 常 像 是 自问 自 答 。 这 会 不 断 引 发 无 关 紧 要 的 新 的 对 话 , 偏离 
了 你 开始 真正 想 寻求 答案 的 问题 。 

口 “ 我 们 ”觉得 加 上 这 个 功能 怎么 样 ? 

口 “ 我 们 ”需要 给 Web 服务 器 加 硬件 吗 ? “Fe” REFR HH 
指标 吗 ? 

口 “ 我 们 ”能 做 什么 来 改善 用 户 体 验 ? 


Bt 


amp 
on 
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这 些 问 题 经 常 是 在 会 议 要 结束 的 时 候 提 出 来 的 , 以 便 安排 另 一 个 
会 议 。 即 使 真正 做 决策 的 只 有 一 两 个 人 ， 每 个 人 也 都 会 说 “我 们 需要 
再 想 想 "。 在 小 组 会 议 或 是 邮件 中 问 这 些 问题 很 正常 ， 但 若 把 冷冰冰 
的 “我 们 ” 换 成 真正 的 人 一 一 你 周围 的 那些 温 血 动物 一 一 这 些 问 题 一 
下 子 就 变 得 直接 了 。 
QO Jennifer 觉得 加 上 这 个 功能 怎么 样 ? 
O Mike 需要 给 Web 服务 器 加 硬件 吗 ? Anthony 能 找 出 性 能 指 
标 吗 ? 
D Tom 能 做 什么 来 改善 用 户 体验 ? 
你 把 问题 指向 某 个 人 的 时 候 ， 人 们 就 会 行动 了 。 


旁观 者 效应 

“我 们 ”类 型 的 问题 经 常会 冒 出 来 ， 因 为 这 是 人 类 的 本 性 。 这 和 
旁观 者 效应 毫 无 二 致 : 出 了 紧急 状况 的 人 , 与 向 一 大 群 旁观 者 求助 相 
比 ， 向 单个 旁观 者 求助 很 可 能 会 更 有 效 。 

根据 社会 影响 的 基本 原理 , 在 紧急 情况 下 , 劳 观 者 会 观察 他 人 的 
反应 , 看 看 他 人 是 不 是 觉得 有 必要 帮忙 。 由 于 每 个 人 都 做 同样 的 事情 
( 即 什么 也 不 做 )， 所 以 他 们 都 会 从 他 人 的 无 动 于 囊 中 得 出 结论 : 不 需 
要 帮助 。” 

劳 观 的 人 越 多 ， 有 人 采取 行动 的 可 能 性 就 越 低 。 所 以 ， 要 明确 指 
定 对 任务 负责 的 那个 人 。 

虽然 听 起 来 很 简单 , 但 把 “我 们 ” 换 成 具体 的 人 名 ( 甚至 是 “我 ”) 
会 让 团队 的 生产 力 大 大 不 同 。 在 会 议 中 ， 在 邮件 中 ,或 是 在 电话 中 ， 
使 用 “我 们 ”都 会 前 弱 动 力 ， 让 你 的 团队 不 清楚 谁 应 该 干什么 ,以 及 


D 参见 http://en.wikipedia.org/wiki/Bystander_effect。 
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谁 不 应 该 干什么 。“ 我 们 ”对 于 生产 力 来 说 就 是 高 果糖 的 玉米 糖浆 ”， 
听 起 来 很 甜 ， 但 里 面 满 是 有 害 健 康 的 东西 。 

我 们 在 上 面 几 篇 文章 中 已 经 看 到 , 有 时 候 提高 生产 力 只 需 降 低 复 
杂 度 : 和 更 少 的 人 工作 , 将 责任 交 给 一 个 人 , 或 是 消除 团队 开发 中 的 
外 部 噪声 。 在 下 一 章 中 ,我 们 会 关注 软件 中 的 复杂 度 。 


D 有 研究 称 ， 高 果糖 玉米 糖浆 可 能 会 引起 肥 
肪 肝 等 健康 问题 ， 但 仍 有 争议 。 


HE, b 


译 者 注 


Ws AR 
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除了 死亡 和 税收 "， 复 杂 性 可 能 是 生活 中 唯一 肯定 存在 的 东西 ， 
它 总 是 随 着 时 间 的 推移 而 增长 。 在 我 们 这 个 行业 , 复杂 性 是 软件 日 渐 
成 熟 不 可 避免 的 后 果 。 除 非 我 们 愿意 删除 软件 中 的 功能 , 否则 根本 没 
有 办 法 避免 。 


Bio o Wea —— 
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“这 到 底 是 什么 意思 ? |” 


O 出 自 富兰克林 的 名 言 :“ 在 这 个 世界 上 ， 除 了 死亡 和 税收 ， 没 有 什么 是 确定 无 疑 
的 。 一 一 译 者 注 


图 灵 社区 会 员 cindy282694 专 享 尊重 版 权 


72 第 5 章 & 杂 性 

如 果 我 们 不 能 摆脱 复杂 性 , 那么 下 一 步 就 只 能 抑制 它 的 增长 。 我 
们 需要 认识 到 什么 时 候 复 杂 性 没有 必要 ,还 要 培养 灵敏 的 “嗅觉 ” 来 
寻找 它 。 如 果 我 们 知道 它 是 什么 “ 味 儿 ”"， 并 且 可 以 在 软件 的 每 一 个 
角落 找到 那 青 熟悉 不 过 的 恶臭 气味 ， 我 们 最 后 就 能 得 到 更 好 的 结果 。 
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所 谓 坏 的 复杂 性 ， 就 是 根本 毫 无 必要 的 复杂 性 。 
这 并 不 总 是 很 容易 发 现 。 有 时 候 ， 即 使 我 们 认为 某 样 东西 很 有 必 
BE, 但 实际 上 也 并 不 是 这 么 回 事 。 这 种 情况 甚至 曾 发 生 在 托马斯 . 杰 
韭 逊 身上 。 
1776 年 ,杰斐逊 是 起 草 《独立 宣言 》 的 委员 会 成 员 ,， 并 有 幸 撰 写 
第 一 稿 。 草稿 完成 后 , 他 把 稿子 寄 给 他 的 朋友 本 杰 明 .富兰克林 审阅 。 
富兰克林 回信 的 时 候 ， 把 杰斐逊 许多 精妙 的 语言 都 删除 了 。 
杰斐逊 不 太 高 兴 ,， 但 富兰克林 试图 说 服 他 的 朋友 为 什么 这 样 更 
好 。 富 兰 克 林 给 他 讲 了 这 个 故事 : 
当 我 还 是 印刷 厂 学 徒 的 时 候 ， 有 个 伙伴 是 制 幅 学 徒 ， 他 
已 经 满 师 ， 打 算 自己 开店 。 
他 首先 想到 的 是 要 有 一 个 漂亮 的 招牌 和 恰当 的 题词 。 他 
写 了 这 么 一 些 话 。 
“约翰 ， 汤普森， 制帽 师 ， 制 作 和 销售 帽子 换取 现金 ” 
后 面 还 画 上 了 一 顶 帽 子 。 不 过 他 觉得 应 该 发 给 朋友 们 ， 
请 他 们 帮忙 修改 一 下 。 
第 一 个 看 到 的 人 认为 “制帽 师 ” 多 余 ， 因 为 后 面 紧 跟 着 
“制作 帽子 ”， 这 已 表明 他 是 一 名 制帽 师 。 于 是 这 个 词 被 别 
掉 了 。 
第 二 个 人 觉得 “制作 ”也 可 以 省 略 ， 因 为 客户 不 会 关心 
帽子 是 谁 做 的 。 如 果 质 量 好 又 合意 ,他 们 就 会 买 ， 不管 它 
谁 做 的 。 于 是 这 个 词 也 去 掉 了 。 
第 三 个 人 觉得 “换取 现金 ”也 没 用 ,因为 当地 并 没有 内 


是 
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每 个 人 买 东 人 于 是 这 个 短语 也 去 掉 


账 的 习惯 ， 
了 ， 现 在 的 题词 就 变 成 了 “约翰 ' 汤普森 销售 帽子 ”。 
“销售 帽子 ! ” a “可 没 人 会 希望 你 免费 


送 啊 。 你 写 这 个 有 什么 用 ? ”于 是 “销售 ”也 被 去 掉 了 。 
“帽子 ”也 跟着 被 去 掉 了 ， 因 为 招牌 上 已 经 有 一 幅 “ 帽 子 ” 
的 画 了 。 

最 后 ， 招 牌 就 被 精简 为 “约翰 汤普森 "， 后 面 画 了 一 项 帽子 。” 
很 多 软件 都 可 以 从 这 个 制帽 师 的 故事 里 得 到 一 点 启示 。 这 个 接生 


非得 有 吗 ? 复制 这 一 行 增加 了 任何 价值 吗 , 还 是 只 是 重复 了 已 有 的 东 
PE? 这 项 新 功能 真 的 有 助 于 任务 的 实现 吗 ? 


考虑 一 下 ， 你 可 以 从 软件 里 面 去 掉 什么 ， 却 丝毫 不 会 影响 功能 。 


D 参见 http://www.pbs.org/benfranklin/l3_citizen_founding.html。 
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第 27 篇 关于 “简单 ”的 悖 论 


让 复杂 性 成 为 一 个 奇怪 现象 的 原因 是 : 每 个 人 都 喜欢 简单 。 所 以 
人 们 党 说 “我 只 是 想 让 事情 简单 一 点 儿 ”"。 有 谁 说 过 “我 只 是 想 让 事 
情 复杂 一 点 儿 ”? 

我 决定 找 找 答 案 ， 于 是 我 在 Google 上 搜索 了 一 下 。 

在 写 这 篇 文章 的 时 候 , 如 果 你 Google“ 我 想 让 事情 简单 一 点 儿 ”， 
大 约会 有 954 000 条 匹配 结果 ， 而 “我 想 让 事情 复杂 一 点 儿 ” 只 有 唯 
一 一 个 匹配 结 

一 个 。 那 么 唯一 的 一 个 匹配 结果 是 什么 ? 那 是 我 于 2009 年 10 月 
就 此 话题 写 的 一 篇 博客 文章 。 如 果 把 我 自己 从 人 类 文明 的 记录 中 剔除 
掉 ， 那 么 很 显然 没有 人 想 要 甚至 想 过 主动 把 事情 变 复杂 。 

那么 , 为 什么 我 们 自己 做 东西 的 时 候 就 遇 到 了 杰斐逊 一 样 的 复杂 
性 问题 呢 ? 为 什么 我 们 生产 的 东西 常常 复杂 无 比 呢 ? 很 多 想法 很 好 
的 软件 怎么 就 从 简单 的 点 子 变 成 了 复杂 功能 的 恶 梦 呢 ? 
简单 的 产品 实际 上 不 好 做 

大 多 数 想法 ， 表 面 看 起 来 简单 ， 可 着 手 细节 的 时 候 却 极度 复杂 。 
高 质量 的 想法 总 是 很 简单 。 每 一 个 商业 构想 都 必须 能 进行 电梯 游说 ， 
即 能 在 60 秒 内 把 想法 从 头 到 尾 讲 清楚 。 我 们 没 法 在 60 秒 内 把 复杂 的 
东西 讲述 清楚 。 

和 觉得 想法 开始 变 得 复杂 的 时 候 ， 我 们 就 离开 了 舒适 的 “想法 ” 
王国 ， 进 入 了 赤裸 裸 的 “实施 ”的 现实 。 一 旦 我 们 深入 细节 ， 就 会 发 
现 所 有 的 逻辑 漏洞 都 在 这 里 。 这 就 是 细节 的 本 质 。 到 了 这 个 时 候 ,，( 大 
部 分 ) 没有 经 过 充分 考虑 的 想法 都 不 太 可 能 不 变 复杂 。 有 时 候 ， 低 着 
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头 蒙 着 有 眼 干 活 比重 新 思考 这 个 想法 要 容易 , 于 是 就 做 出 了 一 些 草 率 的 
决定 ,为 了 坚持 神圣 的 “伟大 想法 ”而 添加 了 功能 。 然 后 ， 软 件 就 变 
得 越 来 越 复杂 了 。 


简单 有 时 似乎 不 够 


如 果 每 个 人 都 喜欢 简单 的 软件 ， 而 大 多 数 软 件 做 起 来 不 简单 , 那 
似乎 最 好 的 情况 就 是 软件 既 简 单 易 用 又 容易 制作 。 这 对 用 户 和 开发 人 
员 来 讲 是 双赢 , 但 世界 上 很 少 有 这 种 软件 。 这 个 谜 里 面 还 涉及 更 多 的 
东西 。 

答案 就 在 于 我 们 自己 对 不 足 的 如 ′ 惧 。 当 我 们 做 了 一 个 简单 的 东西 
时 ， 就 感觉 它 …… 不 够 复杂 。 我 们 说 服 自己 来 相信 ， 客户 的 付出 并 没 
有 得 到 相应 的 回报 。 一 个 本 身 很 简单 、 做 起 来 也 简单 的 东西 让 人 感觉 
毫 无 价值 ， 一 个 很 容易 实现 的 想法 也 很 少 被 视 为 “伟大 的 想法 ”。 

风险 投资 人 不 会 为 简单 的 想法 倾注 数 百 万 美元 , 他 们 把 所 有 的 钱 
都 扔 在 唐纳德 ， 特 朗 普 式 的 极端 追求 上 "。 这 是 同类 中 最 好 的 吗 ? 有 
创新 吗 ? 是 最 尖端 的 吗 ? 很 多 情况 下 , 这 无 非 是 换 了 种 方式 来 说 “一 
个 想法 足够 复杂 ， 所 以 很 有 价值 © 

矛盾 就 在 于 此 。 作 为 开发 者 ,我 们 往往 把 所 做 软件 的 价值 等 同 于 
其 复杂 性 ， 复 杂 度 越 高 就 等 于 价值 越 大。 

用 户 则 有 不 同 的 看 法 。 现实 情况 是 ，90% 的 用 户 只 使 用 普通 企业 
级 软件 中 10% 的 功能 。 如 果 用 户 无 法 在 众多 不 需要 的 功能 下 面 找 出 
需要 的 那个 ,他 们 要 么 怪 自 己 能 力 有 所 不 足 , 要么 就 归 答 于 软件 本 里 。 
开发 者 和 利益 相关 者 把 简单 看 做 缺点 ， 而 用 户 却 把 复杂 看 做 缺点 。 


®© Donald Trump ， 美 国 商业 大 享 、 电 视 名 人 、 畅 销 书 作家 。 他 制作 并 主持 著名 的 电视 
节目 《学 徒 》(4pprentice)， 每 周至 少 淘汰 一 名 候选 人 ， 最 终 聘 用 一 名 员工 。 
一 译 者 注 
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在 我 的 公司 , 我们 一 直抵 制 把 事情 搞 复 杂 的 自然 欲望 。 我 们 必须 
时 时 提醒 自己 ， 要 把 软件 做 得 简单 一 些 。 

我 们 就 自己 软件 的 功能 进行 过 无 数 次 的 内 部 争论 , 但 最 后 都 采用 
了 简单 的 解决 方案 。 有 时 用 户 界 面 只 需要 对 文本 做 出 小 的 调整 ， 有 时 
就 是 重新 整理 一 下 链接 。 有 时 候 我 们 会 就 一 个 新 功能 争论 几 个 小 时 ， 
最 终 决定 不 值得 为 了 这 个 功能 增加 软件 的 复杂 性 。 

我 们 要 学 到 的 教训 是 , 并非 就 功能 讨论 了 好 几 个 小 时 ， 就 一 定 要 
添加 好 多 个 功能 。 我们 很 自然 会 觉得 , 花 在 一 件 东西 上 的 时 间 应 该 和 
其 可 度量 的 产 出 相 匹 配 , 而 不 管 新 功能 到 底 能 带 来 什么 好 处 , 但 是 请 
摆脱 这 种 折磨 人 的 想法 吧 。 一 旦 你 不 再 天 真 地 认为 简单 会 降低 价值 ， 
就 可 以 开发 出 好 的 软件 了 。 

一 个 简单 的 解决 方案 不 应 该 被 认为 是 “ 缺 了 什么 ” ， 有 时 候 ， 它 
恰到好处 。 
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第 28 篇 复杂 性 就 像 挑 棍 游 戏 


挑 棍 是 一 种 古老 的 儿童 游戏 , 参与 者 要 把 一 堆 塑 料 棍 一 根 一 根 挑 
出 来 , 挑 的 时 候 还 不 能 碰 到 其 他 的 小 棍 。 开始 的 时 候 把 一 大 把 小 棍 抓 
EFE, 然后 撤 开 ,之 后 大 多 数 小 棍 会 在 中 间 堆 成 一 堆 ， 少 数 则 会 深 
到 一 边 。 

游戏 的 目标 是 要 从 整 堆 中 挑 走 尽 可 能 多 的 小 棍 , 每 次 一 根 , 不 能 
碰 到 其 他 的 小 棍 。 如 果 碰 到 了 的 话 ， 你 的 这 一 轮 就 算 输 了 。 
维护 复杂 的 软件 有 时 候 感觉 很 像 这 个 游戏 , 其 中 每 个 小 棍 都 代表 
一 个 特性 或 功能 。 有 时 候 一 个 特性 可 以 完全 孤立 ,与 其 他 特性 毫 不 相 
F; 有 时 候 它 会 影响 几 个 组 件 ; 还 有 些 时候 ， 它 和 许多 其 他 特性 紧 紧 
地 交织 在 一 起 。 

植 人 新 功能 就 像 在 堆 里 再 加 上 几 根 新 的 小 棍 。 到 了 某 个 时 候 , 抽 
走 任何 一 根 小 棍 而 不 影响 其 他 的 小 棍 都 几乎 是 不 可 能 的 了 。 复杂 程度 
急剧 增加 。 

作为 开发 人 员 , 我 们 通过 养 成 下 面 这 些 好 习惯 来 尽 可 能 避免 这 个 
问题 : 封装 代码 、 将 变量 定义 到 合适 的 作用 域 、 把 大 块 逻辑 拆 成 小 块 ， 
或 者 引入 模式 。 我 们 努力 让 所 有 的 小 棍 都 并 排 摆 放 、 互 不 接触 ,但 在 
不 断 加 入 新 的 小 棍 的 同时 ， 要 坚持 把 代码 重 构 到 “正确 ”的 位 置 实在 
有 点 环 手 。 这 个 防线 很 容易 就 震 掉 了 。 

每 次 加 入 新 特性 的 时 候 , 我 们 都 可 能 会 干扰 其 他 一 些 最 初 看 起 来 
并 不 直接 相关 的 特性 。 加 入 的 特性 越 多 ,干扰 之 处 也 会 迅速 增多 。 
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第 29 篇 ”把 复杂 性 藏 起 来 


“极其 复杂 的 一 团 乱 肪 。 

美国 国税 局 的 全 国 纳税 人 权益 维护 人 Nina Olson 是 这 样 形容 美 
国税 务 系统 的 。 美 国联 邦 个 人 所 得 税法 案 差 不 多 有 6500 页 。 你 能 想 
象 吗 ? 你 觉得 我 在 撤 谎 ? 那 你 说 对 了 。 它 事实 上 有 65000 页 。 


也 许 正 因为 如 此 ， 

be 
pensan || gic Seo 
屁 不 通 啊 ! 简直 
就 没 打算 让 我 


(tax code), 


这 就 是 我 热爱 TurboTax 的 原因 ， 它 是 美国 最 流行 的 所 得 税 报税 
软件 之 一 。 它 把 这 65 000 页 文档 拿 过 来 ， 然 后 奇迹 般 地 弄 出 了 某 种 
像 我 这 种 普通 人 都 能 够 使 用 的 软件 .TurboTax 本 来 可 以 只 是 把 联邦 和 
州 税 的 1040 表 " 数字化, 把 每 个 项 目 变 成 一 个 文本 框 , 然后 再 做 上 一 
点 点 计算 ， 最 后 通过 信息 高 速 公 路 把 表格 提交 。 

也 许 那样 它 仍然 会 有 许多 粉丝 。 


D 1040 表 是 每 年 个 人 申报 收入 时 需要 填写 的 表格 , 对 于 联邦 税 和 州 税 各 需 填 写 一 份 ， 
如 有 较为 复杂 的 收入 和 支出 情况 还 需要 另 附 其 他 表格 。 译 者 注 


图 灵 社 区 会 员 cindy282694 专 享 尊重 版 权 


80 #58 复杂 性 

但 是 ，TurboTax 没有 这 样 做 。 它 就 像 一 个 个 人 税务 向 导 ， 明 白 
没有 人 真 的 愿意 花心 思 琢 磨 它 。“ 把 你 的 W-2 表格 拿 出 来 "， 把 数字 
抄 给 我 “你 有 农场 吗 ? RA? ! 那 我 们 就 再 也 不 用 提 这 个 了 。” 它 
甚至 知道 ， 在 它 问 我 一 些 古 怪 问 题 的 时 候 ， 要 告诉 我 这 个 情况 十 分 
“这 对 你 也 许 并 不 适用 。” 

TurboTax 真是 一 个 英雄 ， 它 让 报税 成 为 至 少 可 以 接受 的 一 件 事 。 
我 都 能 想象 这 背后 的 逻辑 是 多 么 地 复杂 。 不 光 是 要 有 联邦 法 的 内 容 ， 
五 十 个 州 和 数 以 千 计 的 县 都 要 有 各 自 的 法 案 。 对 于 每 一 个 地 区 来 说 ， 
单身 的 、 结 婚 的 、 小 型 企业 主 、 投资 者 、 学 生 、 慈 善 家 、 首 次 购房 的 、 
失业 的 、 刚 退休 的 、 常 忘 事 的 、 穷 人 、 富 人 、 富 察 ， 啊 对 了 ， 还 有 农 
民 ， 都 得 有 不 同 的 程序 。 

再 加 上 每 年 税法 都 会 有 所 变化 。 为 了 政府 开支 中 的 某 个 专项 资金 
所 去 掉 或 者 加 上 的 每 个 小 规则 ， 最 终 累 积 成 了 这 65 000 页 的 文档 。 
如 果 你 为 多 欠 了 政府 几 百 美元 而 心怀 怨 舍 ， 想 想 那 个 写 TurboTax 的 
程序 员 吧 , 他 还 得 为 过 去 六 个 月 中 在 密西西比 州 买 了 个 环保 摩托 艇 的 
家 伙 再 多 写 上 一 点 儿 诡异 的 条 件 逻 辑 呢 。 

那 这 些 代码 有 没有 重 构 的 价值 呢 ?” 如 果 今 天 写 的 这 段 代码 到 下 
次 国会 休会 的 时 候 就 过 时 了 , 或 者 将 来 依赖 的 参数 完全 不 同 了 , 他 们 
还 能 重 构 什么 呢 ? 

TurboTax 证 明了 , 即使 手头 的 任务 极度 复杂 混乱 ,软件 也 大 可 不 
必 如 此 。 你 可 以 把 所 有 的 复杂 性 都 隐藏 起 来 ， 把 这 团 乱 麻 转化 成 可 
以 让 人 理解 、 让 人 使 用 的 功能 ， 从 而 创造 出 真正 有 意义 且 非 常 简洁 
的 软件 。 


wad 


D W-2 表格 是 全 职 雇佣 关系 中 ， 
清单 。 一 一 译 者 注 


主 在 年 末 发 给 员工 的 全 年 工资 和 所 得 税 预 扣 情 况 的 


a 

a 

过 
y 
g 
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第 30 篇 “ 难 编 ” 可 能 意味 着 “ 难 用 ” 


TurboTax 把 一 个 几乎 不 可 能 理解 的 东西 变 得 易于 众人 使 用 , 它 把 
复杂 性 从 用 户 那里 转移 到 了 代码 里 。 

然而 ,这 种 转移 并 不 总 是 一 个 零 和 博弈 。 有 时 候 ， 过 分 复杂 的 罗 
辑 是 软件 功能 模糊 不 清 的 信号 。 用 复杂 代码 去 支持 复杂 界面 ? 我 们 能 
不 能 不 要 这 些 呢 ? 
电梯 中 的 困惑 

想像 我 们 在 一 个 工程 师 小 组 里 ， 试 图 为 一 栋 50 层 高 的 大 厦 设计 
一 套 更 好 的 电梯 控制 软件 。 电梯 可 以 监控 人 们 从 哪 层 楼 进入 以 及 按 了 
哪 层 楼 的 按钮 。 我 们 的 经 理 走 进 来 ,只 提出 一 条 要 求 : 人 们 都 抱怨 在 
电梯 里 面 等 待 的 时 间 太 长 , 设计 的 时 候 要 让 人 们 呆 在 电梯 里 的 总 时 间 
最 短 。 


“不 ， 我 表 定 是 错过 去 了 。” 
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我 们 开始 集体 讨论 各 种 场景 。 假 设 约翰 从 一 楼 进来 , 按 下 按钮 要 
到 他 位 于 第 50 层 的 顶层 公寓 。 半 途中 ， 电 梯 停 在 了 8 层 。UPS 的 快 
递 员 史 蒂 夫 走 进 来 ， 拿 着 一 个 棕色 大 纸箱 。 他 要 给 5 层 的 人 送 包 豪 ， 
于 是 他 迅速 地 按 了 5。 

那 电梯 应 该 怎么 办 呢 ? 是 因为 离 5 层 比较 近 而 应 该 先 下 到 5 层 ， 
还 是 因为 正在 向 上 走 而 应 该 后 停 在 5 层 呢 ? 

如 果 电 梯 下 到 5 层 ， 那 么 约翰 和 史 蒂 夫 总 共 要 走 过 58 个 楼 层 。 
约翰 先 向 上 7 层 ， 向 下 3 层 ， 然 后 再 向 上 走 完 剩 下 的 45 层 ， 到 达 他 
的 顶层 公 寅 。 史 蒂 夫 只 需要 向 下 3 层 。 

口 约翰: 向 上 7 层 + 向 下 3 层 + 向 上 45 层 = 经 过 了 55 层 。 
口 史 蒂 夫 ; 向 下 3 层 = 经 过 了 3 层 。 
D 约翰 和 史 带 夫 总 共 经 过 的 楼 层 数 : 58。 

我 们 来 比较 一 下 另 一 种 方式 。 如 果 电 梯 继 续 向 上 走 ， 然 后 再 下 到 

5 层 ， 那 么 他 们 就 要 经 过 两 倍 多 的 楼 层 数 。 

口 约翰 : 向 上 49 层 = 经 过 了 49 层 。 

a ER: 向 上 42 层 + 向 下 45 层 = 经 过 了 87 层 。 
D 约翰 和 史 蒂 夫 总 共 经 过 的 楼 层 数 : 136。 

答案 很 明显 。 电 梯 应 该 向 下 ， 先 送 史 蒂 夫 和 他 的 棕色 大 纸箱 ， 然 
后 再 一 路 上 到 约翰 的 顶层 公寓 。 我 们 都 觉得 新 电梯 肯定 会 棒 极 了 ! 

我 们 再 继续 想象 一 下 。 假 设 UPS 快递 员 史 蒂 夫 是 在 30 层 而 不 是 
8 层 进来 的 ， 那 么 电梯 要 是 先 下 来 就 会 出 现下 面 这 种 结 
口 约翰 : 向 上 29 层 + 向 下 25 层 + 向 上 45 层 = 经 过 了 99 层 。 
a ER: 向 下 25 层 = 经 过 了 25 层 。 

D 约翰 和 史 蒂 夫 总 共 经 过 的 楼 层 数 : 124。 
那 电梯 要 是 先 一 路 向 上 ， 到 约翰 的 顶层 公寓 之 后 再 向 下 呢 ? 
口 约翰 : 向 上 49 层 = 经 过 了 49 层 。 
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a ER: 向 上 20 层 + 向 下 45 层 = 经 过 了 65 层 。 
口 约翰 和 史 蒂 夫 总 共 经 过 的 楼 层 数 .114。 

在 这 种 情况 下 ， 如 果 电 梯 向 上 ， 我们 就 节约 了 10 个 “人 层 ”! 所 
以 , 根据 史 带 夫 从 哪 一 层 进来 ,电梯 会 决定 是 继续 向 上 ，, 还 是 先 向 下 
再 向 上 。 如 果 是 两 个 人 乘 电梯 , 那么 编程 解决 他 们 乘 电 梯 的 最 优 方 案 
还 算是 个 简单 的 任务 。 

现在 假设 还 有 第 三 个 人 一 一 萨 曼 莎 进入 了 电梯 , 那么 我 们 让 谁 先 
下 电梯 就 有 了 六 种 可 能 的 方案 。 我们 的 程序 需要 计算 每 种 方案 所 经 过 
的 总 楼 层 数 ， 然 后 找 出 最 优 路 线 。 
口 情况 1: Ay, BRER, Peay 
口 情况 2: Ay, pRB, BAK 
口 情况 3: EER, A, BRB 
口 情况 4: BAR, BR, A 
口 
口 


情况 5: BREWS, aA, 约翰 
情况 6: PEW, A, BR 
事实 上 ， 需 要 测试 的 情况 数 就 是 任意 时 刻 电 梯 中 总 人 数 的 阶乘 ; 
口 2 个 人 =2!=2 次 比较 
口 3 个 人 =3!=6 次 比较 
口 4 个 人 =4!=24 次 比较 
口 8 个 人 =8!=40320 次 比较 
一 旦 数目 超过 了 几 个 人 , 要 测试 所 有 情况 就 变 得 不 可 行 了 。 但 这 
只 是 复杂 性 问题 的 一 个 方面 而 已 。 
人 们 会 在 不 同 的 时 间 上 下 电梯 。 每 次 有 新 的 人 进入 电梯 ,我们 就 
需要 记录 现 有 的 乘客 已 经 经 过 了 多 少 楼 层 ， 然 后 再 开始 新 的 计算 。 
换 句 话说 , 光 是 看 看 现在 电梯 里 面 有 谁 , 我 们 无 法 推断 出 电梯 已 
经 走 过 的 路 线 。 如 果 迈 克 在 25 层 进来 ,然后 桑 杰 在 35 层 进来 ， 那么 
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在 迈克 和 和 桑 杰 先后 进入 的 这 段 时 间 里 ， 电 梯 是 只 走 过 了 10 层 ， 还 是 
先 下 到 21 层 去 送 了 萨 曼 莎 呢 ? 

有 两 位 以 上 乘客 的 时 候 ， 我 们 还 必须 记录 人 们 什么 时 候 下 了 电 
梯 ， 这 样 之 后 的 计算 中 就 不 用 考虑 他 们 了 。 

此 外 ， 要 是 有 人 忘 了 按 楼 层 ， 或 是 按 错 了 楼 层 ， 然 后 半路 上 又 
按 了 个 按钮 呢 ? 我 们 的 软件 需要 重新 计算 ， 并 且 可 能 要 半路 改变 方 
式 吗 ? 

如 果 你 是 编程 新 手 ， 很 不 幸 ， 一 点 都 不 夸张 ， 诸 如 让 人 们 尽快 走 
下 电梯 这 样 一 个 看 似 简单 的 目标 ， 最 后 可 能 会 变 得 非常 复杂 。 


没有 什么 回报 的 复杂 性 


假设 , 克服 了 那些 人 额外 的 障碍 之 后 , 我 们 设法 做 出 了 完美 的 系统 ， 
写 出 的 代码 可 以 让 大 家 采 在 电梯 里 的 总 时 间 最 短 一 一 在 一 瞬间 就 计 
算 了 成 千 上 万 的 情况 , 并 考虑 了 每 个 人 走 过 的 路 线 。 这 真是 一 座 技术 
的 丰碑 ! 但 约 输 、 史 蒂 夫 和 其 他 人 感觉 如 何 呢 ?” 可 能 并 不 怎么 好 。 

代码 最 擅长 处 理 那 些 繁 宛 又 可 以 自动 化 的 东西 , 诚然 这 就 是 一 个 
极端 繁杂 的 例子 。 但 人 却 不 大 擅长 这 个 。 站 在 电梯 里 ， 没 人 能 够 很 快 
地 在 脑子 里 计算 所 有 的 情形 。 等 着 走 下 电梯 的 人 完全 是 受 电梯 摆布 ， 
不 知道 下 一 个 人 上 来 以 后 会 往 哪 个 方向 走 ， 也 不 知道 为 什么 。 

这 就 是 一 个 难 编 就 意味 着 难 用 的 例子 。 在 这 个 例子 里 , 复杂 性 对 
双方 都 造成 了 损害 。 只 要 有 第 四 个 人 走 进 电梯 ,情况 就 会 变 得 太 复杂 ， 
人 脑 就 无 法 知道 电梯 想 往 哪个 方向 走 了 。 即使 电梯 正在 实现 让 所 有 人 
走 过 的 总 楼 层 数 最 少 的 目标 , 电梯 里 的 人 也 不 知道 什么 时 候 才 能 轮 到 
自己 下 电梯 。 

他 们 可 能 更 喜欢 那 种 简单 传统 的 电梯 算法 。 

当然 , 这 可 能 并 不 是 最 优 线路 , 但 采用 一 种 比较 简单 的 方案 , 电 
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梯 里 的 人 就 更 了 解 现实 的 情况 。 用 户 对 可 预见 性 的 要 求 胜 过 了 更 复杂 
的 方案 ， 即 使 这 种 方案 在 理论 上 效率 更 高 。 
如 果 细 节 变 得 异常 难 编 , 这 可 能 意味 着 系统 的 实际 功能 难以 让 人 
理解 。 你 可 能 在 编 好 了 无 比 复杂 的 东西 之 后 松 了 一 口气 , 但 别人 在 用 
过 之 后 可 能 对 你 恨 得 咬牙 切 齿 。 
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第 31 篇 ”知道 何 时 重 构 


写 代 码 时 要 是 想 得 太 长 远 , 也 会 导致 复杂 性 的 问题 。 对 要 编写 的 
实际 的 东西 太 过 敏锐 或 是 太 过 理性 , 是 要 付出 代价 的 。 一 个 经 典 案 例 
就 是 过 早 地 运用 设计 模式 。 

不 要 误解 我 的 话 , 设计 模式 是 很 好 的 东西 。 一 个 通用 的 编程 方法 
反复 出 现 之 后 , 我 们 就 会 兴奋 起 来 。 我们 都 体验 过 这 种 感觉 : 自己 的 
代码 不 仅 可 以 完成 手头 的 具体 任务 ， 还 可 以 做 更 大 的 事 儿 。 

有 了 几 次 这 种 体会 , 成 功 地 把 代码 重 构成 更 抽象 的 模式 之 后 , 我 
们 很 容易 有 种 所 向 披 麻 的 感觉 ,我 们 像 警 厂 一 样 , 嗅 出 所 有 的 小 信号 、 
小 线索 ， 以 及 所 有 可 以 对 我 们 直 白 的 代码 进行 抽象 的 暗示 。 

但 很 快 , 我 们 的 第 六 感 就 会 反咬 我 们 一 口 ， 让 我 们 鲜血 淋漓 。 很 
多 人 都 听 说 过 或 者 体验 过 “用 架构 把 自己 允 入 死角 ”的 恐怖 故事 ,这 
就 是 用 抽象 方法 来 解决 问题 时 用 得 过 头 了 。 


过 早 重 构 的 危险 


打 个 比方 , 假设 你 正在 为 “萌芽 网 络 ” 公 司 做 内 网 , 该 公司 不 大 ， 
只 有 两 个 部 门 : IT 和 销售 。 公司 的 高 管 希望 能 够 根据 一 组 员工 参数 来 
计算 员工 的 预期 奖金 ， 但 每 个 部 门 计算 奖金 的 标准 却 不 同 。 

IT 部门 只 想 按照 员工 当前 工资 的 某 个 百分比 来 发 放 奖 金 ,并 且 只 
发 给 在 公司 工作 了 五 年 以 上 的 员工 。 销 售 部 门 希望 给 所 有 人 1000 美 
元 的 基础 奖金 ， 再 根据 他 们 在 公司 工作 的 年 限 ， 每 工作 一 年 就 增加 
500 美元 的 额外 奖金 。 毕 竞 , 公司 正在 鞍 勃 发 展 ,高 管 也 都 挺 慷慨 的 。 

于 是 你 开始 编程 。 你 先 定 义 了 一 个 Employee 类 ， 包含 计算 员工 
奖金 所 需要 的 所 有 信息 , 然后 写 了 个 简单 的 函数 ,暂时 只 包含 一 个 简 
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单 的 条 件 语句 来 返回 某 个 员工 的 预期 奖金 。 


public decimal GetBonusForEmployee(Employee employee) 


{ 


if (employee.department == Departments.IT) 


{ 
//# IT 部 门 的 方式 计算 奖金 
if (employee.Years >= 5) 


{ 


return .1 * employee.Salary; 


return 0; 


} 


else 


i // 按 销售 部 门 的 方式 计算 奖金 
return 1000 + 500 * employee.Years; 

} 

你 写 了 个 小 工具 来 把 所 有 的 员工 都 加 载 到 一 组 Employee WH 
中 ， 然 后 对 每 一 个 对 象 应 用 上 述 方法 。 搞 定 ， 该 去 喝 一 杯 了 。 

但 是 你 开始 思考 ， 当 萌芽 网 络 公 司 真 的 开始 “发 芽 ” 的 时 候 会 出 
现 的 其 他 可 能 性 。 要 是 出 现 第 三 个 、 第 四 个 部 门 呢 ? 把 条 件 逻 辑 换 成 
switch 语句 ! 那 还 等 什么 呢 ?” 现 在 就 未 雨 绸 织 ， 为 未 来 做 好 准备 : 


public decimal getBonusForEmployee(Employee employee) 


{ 


switch(employee. department) 


{ 


case Departments. IT: 


// 按 IT 部 门 的 方式 计算 奖金 
if (employee.Years >= 5) 


{ 


return .1 * employee. Salary; 
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return 0; 
case Departments .SALES: 


// 按 销售 部 门 的 方式 计算 奖金 
return 1000 + 500 * employee. Years; 
} 
} 


于 得 漂亮 ! switch 语句 是 一 个 很 安全 的 预见 性 做 法 。 它 明确 地 
写 出 了 “销售 部 门 ”， 而 不 是 把 它 放 在 else 语句 里 。 如 果 以 后 有 了 
市 场 部 ， 你 就 知道 应 该 把 它 放 在 哪里 。 

这 个 小 的 重 构 挺 有 道理 的 。 你 的 代码 现在 更 明确 , 也 更 容易 快速 
浏览 ， 换 一 个 程序 员 来 也 可 以 马上 上 手 。 

你 意识 到 了 自己 更 崇高 的 使 命 , 于 是 决定 继续 下 去 。 要 是 两 个 部 
门 变 成 了 …… 十 个 呢 ? 几 个 月 以 后 , 可 能 就 会 冒 出 很 多 新 部 门 ， 比 如 
法 务 部 啊 ， 生 产 部 啊 ， 财 务 部 啊 ， 还 有 清洁 服务 部 ， 等 等 。switch 
语句 最 终 会 变 得 很 腔 肿 , 它 会 沾 上 很 多 并 没有 什么 业务 内 涵 的 复杂 运 
算 ， 它们 全 都 赤裸 裸 地 暴露 在 这 个 计算 奖金 的 方法 表面 。 

你 急匆匆 地 翻 了 翻 心爱 的 设计 模式 书 ( 我 极力 推荐 Joshua 
Kerievsky 的 《 重 构 与 模式 》[Ker04] )， 找 到 了 策略 (Strategy ) 模式 ! 
把 所 有 单个 的 奖金 计算 都 放 到 各 自 的 策略 类 里 ( 比如 ITBonus 
CalculationStrategy 和 SalesBonusCalculationStrategy ), 它 
们 都 是 奖金 计算 策略 接口 (IBonusCalculationStrategy ) 的 实现 。 
这 个 接口 要 求 每 个 实现 类 都 定义 一 个 CalculateBonus() 方 法 。 

完成 之 后 , 你 修改 了 Employee 类 , 让 它 包含 一 个 具体 的 策略 实 
例 ， 然 后 建立 了 一 个 新 的 公共 方法 来 返回 员工 的 奖金 。 

有 了 策略 模式 ， 你 现在 就 可 以 把 getBonusForEmpLoyee ( ) 方 法 
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整个 去 掉 了 。 对 员工 奖金 的 计算 可 以 完全 由 类 本 身 完 成 了 。 于 是 , 所 有 
那些 复杂 的 算法 都 会 优雅 舒适 地 藏 在 TBonusCalculationStrategy 
接口 的 各 个 实现 之 下 。 

既然 都 做 了 这 么 多 了 ， 你 决定 再 来 “打扮 ”一 下 你 的 代码 。 你 把 
员工 的 创建 抽象 成 了 一 个 工厂 ( Factory ) 模式 , 这 样 你 就 可 以 针对 部 
门 来 编写 员工 创建 器 类 ， 为 员工 分 配 相应 的 奖金 策略 。 

你 已 经 完全 去 掉 了 针对 部 门 的 条 件 判 断 ( 这 由 员工 创建 器 类 负责 
T), 繁复 的 计算 逻辑 也 没有 了 ( 藏 在 了 各 个 部 门 的 策略 类 下 面 )。 这 
HERET! 

一 旦 有 了 第 15 个 部 门 ， 这 个 架构 简直 就 是 一 幅 宏 伟 的 画卷 。 

日 复 一 日 ， 月 复 一 月 。 骞 冬 已 至 ， 萌 芽 网 络 公司 开始 举步维艰 。 
公司 没有 设立 新 的 部 门 ， 并 且 奖 金 的 逻辑 也 变 了 。 你 重新 上 手 ， 却 
在 想 你 那 曾 经 简单 的 逻辑 哪里 去 了 。 啊 ,对 了 , 已 经 都 策略 化 、 工 厂 
化 了 。 

又 过 了 几 个 月 。 萌 芽 网 络 公 司 打 电 话 过 来 ， 说 他 们 解雇 了 整个 销 
售 团 队 ， 只 剩 下 CEO 和 开发 团队 了 。CEO 想 保持 开发 人 员 的 士气 ， 
所 以 仍然 想 给 员工 发 奖金 ， 但 现在 完全 是 看 工作 年 限 了 。 

现在 真 该 身 了 。 你 把 所 有 的 赌注 都 押 在 了 按 部 门 而 设 的 奖金 规则 
Eo 话说 回来 , 一 年 之 前 这 还 是 个 挺 安全 的 想法 。 你 大 动 干 区 ,大 张 
WER, 使 之 能 够 解决 接 下 来 一 百年 所 有 部 门 的 奖金 问题 , 但 现在 整个 
重 构 都 付 诸 东 流 了 。 这 不 光 是 过 度 架构 造成 的 混乱 ,也 是 变质 造成 的 
混乱 。 你 把 整个 策略 类 推翻 ， 去掉 了 工厂 方法 ,并 乖乖 地 决定 ,现在 

个 可 能 令 人 厌恶 但 还 不 错 的 条 件 语句 就 足够 了 。 
模式 是 很 棒 的 概念 ,但 实施 起 来 却 要 万 分 小 心 。 预 见 未 来 的 逻辑 
经 常会 导致 意 想 不 到 的 复杂 性 。 
要 说 有 什么 黄金 法 则 的 话 , 那 就 是 不 应 该 强行 把 软件 变 成 一 个 或 
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一 组 记录 完好 的 设计 模式 。 相 反 , 一 个 (或 一 组 ) 设计 模式 的 实施 ， 
应 该 刚好 能 够 满足 软件 的 预期 任务 以 及 近期 最 可 能 出 现 的 应 用 场景 。 
当 你 学 习 设计 模式 的 时 候 , 要 把 它 理 解 为 解决 特定 问题 的 常规 方 
法 ， 而 不 是 某 个 问题 的 固定 标准 答案 。 模 式 都 有 优 缺 点 。 虽 然 模式 会 
证 某 些 任务 完成 得 更 为 优雅 , 但 你 总 会 付出 些 别 的 代价 。 既 然 如 今 的 
网 络 应 用 都 在 根据 新 的 客户 需求 不 断 变化 , 想 要 一 开始 就 找到 "完美 ” 
的 模式 是 不 现实 的 。 
这 是 说 我 们 一 点 都 不 要 预见 变化 吗 ? 不 是 的 。 当 我 们 没有 注意 加 
构 的 方向 是 否 正确 时 ， 问 题 就 来 了 。 


玻 于 管理 的 遗留 代码 让 人 头疼 


随便 挑 一 个 即使 必要 时 编者 也 不 愿意 做 简单 重 构 的 代码 吧 , 你 很 
快 就 会 发 现 问题 的 。 变 量 定义 的 范围 不 对 ,或 者 更 粳 糕 的 是 ， 都 是 全 
局 变量 , 然后 用 一 些 诡 异 的 命名 法 则 来 保证 它们 的 唯一 性 。 条 件 逻 辑 
读 起 来 就 像 是 软件 的 使 用 条 球 : 一 大 堆 毫 不 相干 的 事实 用 and 和 or 
硬 扯 到 一 起 , 下 一 个 非得 修改 它 的 那个 不 幸 的 家 伙 根 本 看 不 出 这 一 团 
乱 麻 是 什么 。 

在 那些 在 程序 员 手 中 轧 转 流传 的 遗留 代码 中 经 常 能 看 到 这 种 问 
rl, 这 帮 人 上 和 手 的 时 候 就 没什么 激情 ,完工 的 时 候 就 更 是 懈 仍 。 方法 
识别 标志 杂乱 无 章 , 方法 调用 乱七八糟 ,简直 连 代 码 自己 都 不 知道 自 
己 在 干什么 ， 例 如 : 


calculateBonusesForTeam(.02, 155000, null, 0, 0, null, 
new Employee(), null, null, false, true); 


随 着 时 间 推 移 , 被 忽视 的 重 构 会 让 你 付出 很 大 的 代价 。 训 无 征兆 
地 ， 代 码 维护 起 来 越 来 越 慢 。 不 要 说 大 的 改动 了 ， 即 使 是 小 的 改动 ， 
那些 我 们 觉得 理所当然 的 小 改动 , 都 可 能 让 一 套 长 期 没有 遵循 哪怕 一 
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我 们 回 到 萌芽 网 络 公 司 的 例子 上 。 某 个 时 候 , 将 奖金 计算 重 构成 
策略 模式 可 能 会 有 意义 ,把 员工 的 创建 方法 变 成 工厂 类 也 可 能 会 有 
用 ， 只 是 当时 的 时 机 不 对 。 

在 开发 周期 中 过 早 地 过 度 架 构 ， 就 会 留 下 一 个 没 填 满 的 坑 ， 而 架 
构 不 足 ， 就 会 让 我 们 丧失 继续 改进 软件 的 选择 或 动力 。 


“漏洞 和 补丁 应 当 大 小 相当 。” 
一 一 出 自 “ 托 马 斯 * A Rubs Bur A iba” 


UVES SED ARUN ASD , 富兰克林 在 几 年 前 的 对 话 传达 
了 一 下 。 

有 所 预见 , 但 要 谨慎 预见 。 无论 是 小 的 改动 , 还 是 大 的 模式 变化 ， 
每 次 决定 重 构 的 时 候 ， 都 要 知道 你 会 得 到 什么 、 失 去 什么 。 
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第 32 篇 ”确定 编程 的 节奏 


那 我 们 怎么 处 理 预 见 过 早 和 反应 过 迟 的 问题 呢 ? 

把 软件 开发 想象 成 开 手 动 挡 的 车 吧 。 起步 的 时 候 , 我 们 挂 的 是 一 
挡 : 稳 稳 地 迈 出 编程 的 脚步 。 编 得 越 多 ,我 们 的 效率 就 越 低 。 到 了 茶 
个 时 刻 ， 我 们 就 得 加 挡 了 。 

加 一 挡 ， 用 编程 的 话 来 说 ， 就 是 清理 代码 : 退 后 一 步 ， 重 构 、 抽 
象 或 是 实施 一 种 模式 。 这 意味 着 ， 在 开发 过 程 中 ， 到 了 某 个 时 候 ， 要 
花 些 时 间 来 考虑 如 何 改变 我 们 的 习惯 。 这 样 做 并 不 意味 着 我 们 先前 做 
错 了 。 相 反 ， 这 是 自然 的 ， 是 必要 的 。 

编程 和 开车 一 样 也 要 换 挡 : 要 是 换 得 太 早 , 就 得 花 好 多 时 间 才 能 
恢复 到 原来 的 速度 ; 要 是 换 得 太 晚 (或 者 干脆 不 换 )， 我 们 的 代码 就 
会 进展 缓慢 。 所 以 , 知道 什么 时 候 换 挡 是 很 重要 的 。 这 会 让 开发 过 程 
尽 可 能 高 效 地 运行 。 我们 不 是 为 了 换 挡 而 换 挡 , 而 是 在 该 换 的 时 候 必 
须 换 。 我 们 要 找到 自己 的 编程 节奏 。 


“我 开 得 太 快 了 ， 所 以 我 觉得 我 还 是 盯 着 路 吧 ， 不 要 看 速度 表 了 。” 
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软件 开发 中 没有 一 定 的 挡 数 。 编 程 的 节奏 里 可 以 只 有 5 挡 ， 也 可 
以 有 50074, 这 取决 于 项 目的 复杂 度 和 规模 ， 以 及 我 们 自己 换 挡 的 意 
愿 。 越 复杂 的 项 目 , 就 要 多 留 出 些 挡 位 ,这样 我 们 可 以 换 得 更 勤 。 这 
意味 着 如 果 我 们 换 得 早 了 点 儿 , 用 不 了 多 少时 间 就 可 以 恢复 速度 ; 要 
是 晚 了 点 儿 ， 也 不 会 对 进度 产生 太 大 影响 。 对 于 小 项 目 来 说 ,只 要 几 
个 挡 就 够 了 。 

归根 结 底 ， 软 件 的 复杂 性 是 必要 的 ， 这 是 为 添加 更 多 的 功能 所 付 
出 的 代价 。 关 键 是 要 知道 什么 时 候 复杂 是 好 的 、 什 么 时 候 是 不 好 的 。 
让 自己 的 第 六 感 告 诉 你 , 这 一 次 , 复杂 性 让 所 有 人 都 受害 。 正 是 因为 
这 个 原因 ， 我 们 的 工作 更 像 是 艺术 而 不 是 科学 。 

复杂 性 是 我 们 在 行业 里 浸润 多 年 之 后 才能 够 更 好 地 理解 的 东西 
之 一 。 编 程 老手 都 能 够 很 好 地 管理 它 。 总 体 来 说 , 我 们 需要 把 这 种 智 
慧 传承 给 未 来 一 代 代 激 情 洋 溢 的 程序 员 们 。 在 下 一 章 里 , 我 们 会 谈 谈 
如 何 成 为 更 优秀 的 程序 员 ， 同 时 又 成 为 更 出 色 的 老师 。 


图 灵 社 区 会 员 cindy282694 专 享 尊重 版 权 


SB 
CN 
sh 


不 论 在 什么 领域 , 教学 都 是 最 难 掌握 的 事情 之 一 。 世 界 上 有 许 许 
多 多 的 专家 ， 但 是 教育 家 就 少 得 多 了 。 

教学 不 光 是 把 我 们 知道 的 东西 说 出 来 , 更 是 一 门 艺术 ,， 它 需要 我 
们 将 自己 的 所 学 传授 给 一 个 正在 学 习 新 知识 的 人 。 掌握 知识 只 是 成 为 
一 名 成 功 的 教师 所 必 备 的 要 素 之 一 。 

我 们 经 常会 希望 一 个 学 识 渊博 的 人 也 是 一 位 优秀 的 教师 , 但 事实 
并 非 总 是 如 此 。 以 赛 亚 :托马斯 是 跻身 NBA 名 人 堂 的 著名 控 球 后 卫 ， 
他 12 次 人 选 NBA 全 明星 赛 ， 并 率领 底特律 活塞 队 两 次 夺取 NBA 总 
冠军 。 然 而， 作为 一 名 主教 练 ， 他 的 战绩 平平 一 一 187 胜 ，223 fo 
有 些 人 拥有 渊博 的 学 识 和 高 超 的 技术 , 却 无 法 将 这 些 特 质 传递 给 他 们 
的 学 生 。 

给 新 手 讲 授 编 程 概念 可 能 还 要 困难 得 多 。 我 们 没有 类 似 于 胜 负 场 
数 这 种 明显 的 指标 ， 很 难 衡量 学 生 是 否 真 的 接受 了 讲授 的 内 容 。 

对 于 我 们 来 说 ， 从 发 现 问 题 到 解决 问题 的 过 程 可 能 相当 复杂 , 很 
难 描述 我 们 究竟 是 如 何 找到 最 后 的 解决 办 法 的 。 但 描述 清楚 这 个 过 程 
至 关 重 要 ， 因 为 这 是 我 们 培养 新 一 代 激 情 洋溢 的 程序 员 的 最 好 方式 。 

在 这 一 章 里 ,我们 会 讨论 一 些 需 要 避免 的 常见 行为 ， 以 及 如 何 帮 
助 他 人 掌握 我 们 头脑 中 所 有 复杂 的 知识 。 
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第 33 篇 ”教学 不 同 于 编程 


乍 一 想 ， 出 色 的 程序 员 似乎 应 该 拥有 成 为 优秀 教师 所 需 的 全 部 


毕竟 ,编程 和 教学 还 是 有 很 多 共通 之 处 的 。 在 那些 花 里 胡 哨 的 语 
法 下 面 , 代码 不 过 是 一 套 实 实在 在 的 指令 集 , 告诉 框架 如 何 去 做 某 些 
事情 。 即 使 有 一 个 极其 微小 的 细节 落下 了 ,我 们 也 能 够 很 快 发 现 , 因 
为 编译 器 会 “大 声 告 诉 ” 我 们 的 。 
编程 也 要 求 我 们 按照 一 定 的 顺序 来 进行 。 我 们 不 能 还 没 定义 概念 
就 去 实现 它 ， 正 如 我 们 不 能 在 一 个 人 还 不 明白 加 法 的 时 候 就 教 他 乘 
法 。 

男 一 方面 ,编程 和 教学 可 以 说 是 相去 其 远 。 实 际 上 , 编程 的 一 些 
坏 习 惯 完全 无 益 于 教学 。 

首先 ， 编 程 很 少 是 按部就班 进行 的 。 我 们 写 代码 时 不 会 一 页 纸 从 
头 写 到 尾 ， 而 是 不 停 地 在 代码 里 跳 来 跳 去 ， 劳 观 者 可 能 看 不 出 我 们 实 
现 功能 的 顺序 。 这 在 我 们 调整 细节 的 时 候 特别 明显 一 一 这 里 改 个 变量 
名 , 那里 修正 一 个 数据 类 型 。 要 是 按照 编程 这 一 套 来 搞 教 学 , 那 讲 课 
的 人 就 会 结 结 巴巴 、 反 反复 复 , 而 听课 的 人 则 会 云 里 雾 里 、 迷 王 不 解 。 
其 次 ， 编 程 可 以 让 我 们 暂时 不 考虑 细节 。 例 如 , 在 重新 定义 一 个 
公用 方法 的 输入 参数 时 ,我 把 方法 的 识别 标志 改 掉 了 , 然后 重新 编译 。 
我 明知 道 这 个 代码 是 编译 不 过 去 的 。 我 知道 会 弹出 一 串 错误 ， 只 要 一 
调用 这 个 方法 , 它们 就 会 跳出 来 说 参数 类 型 不 匹配 。 但 我 这 样 做 的 原 
因 在 于 ， 比 起 看 遍 所 有 的 代码 或 是 手动 查找 调用 , 这 种 方法 能 更 加 快 
速 地 找 出 我 需要 修改 的 其 他 地 方 。 

通常 , 我 们 编译 代码 并 不 是 因为 觉得 工作 已 经 完成 了 ,而 是 想 要 
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找 出 哪里 还 有 缺失 。 编 译 器 是 懒惰 的 程序 员 最 好 的 朋友 ， 单 元 测试 、 
代码 提示 和 自动 补 全 也 是 。 

所 有 这 些 细节 对 于 高 效 编程 来 说 都 是 至 关 重 要 的 。 它 们 就 像 柔 软 
而 有 弹性 的 墙 ， 把 我 们 的 代码 “ 弹 ” 回 来 。 它 们 使 我 们 得 以 先 注重 大 
局 ， 而 不 用 太 关 注 代 码 是 否 完美 。 好 的 编程 平台 会 自动 帮 我 们 “ 探 净 
嘴角 ”、 修 正 语法 ， 并 且 在 我 们 写 出 的 指令 不 那么 连贯 的 时 候 ， 告 诉 
我 们 真正 的 意图 是 什么 。 编 程 越 快 、 越 高 效 , 我 们 就 越 依赖 于 这 些 工 
具 来 找到 正确 的 方向 。 

教 一 个 新 手 可 完全 不 是 这 么 回 事 。 忽略 的 细节 就 全 都 丢掉 了 。 我 
们 不 能 说 前 半 句 , 然后 指望 学 生 接 上 后 半 句 , 至 少 一 开始 不 行 。 MH, 
人 与 编译 需 不 同 , 一 旦 我 们 改 掉 错误 ， 编 译 器 就 会 把 过 去 的 错误 忘 得 
一 干 二 净 , 但 人 无 法 将 对 与 错 分 得 清 清 楚楚 。 我 们 可 能 要 编译 十 几 遍 
才能 让 代码 跑 通 , 但 是 想 想 看 , 要 是 教学 的 时 候 也 反复 修改 多 遍 才 搞 
对 ， 那 学 生 该 多 么 不 知 所 措 。 

高 效 编程 的 这 些 古 怪 习 惯 实在 是 和 循序 渐进 的 教学 原则 格格 不 
入 。 你 不 能 把 一 堆 概 念 扔 给 学 生 ， 省 掉 几 个 细节 ， 然 后 希望 他 们 能 够 
准确 领会 你 的 意思 。 你 不 会 得 到 错误 代码 和 警告, 却 只 会 看 到 学 生 们 
茫然 的 眼神 。 

就 算是 无 比 杰出 的 程序 员 ， 也 不 一 定 是 合格 的 教师 。 
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第 34 篇 当心 “知识 魔 咒 " 


Chip 和 Dan Heath 兄弟 合 著 了 一 本 畅销 书 《 粘 住 : 为 什么 我 们 记 
住 了 这 些 ， 忘 掉 了 那些 ? 》( Made to Stick: Why Some Ideas Survive and 
Others Die ) [HH07]， 作 者 称 一 旦 你 成 了 某 个 领域 的 专家 ， 就 几乎 不 
可 能 明白 对 这 个 领域 一 无 所 知 是 什么 感觉 。 

想 想 你 该 如 何 向 一 个 先天 失明 的 人 解释 什么 是 颜色 , 或 者 向 先天 
失聪 的 人 解释 什么 是 声音 。 举 个 不 那么 极端 的 例子 ， 想 想 律 师 吧 ， 如 
果 没 有 各 种 抽象 和 限定 ， 他 就 没 法 准确 回答 法 律 问题 。 

他 们 把 这 种 现象 称 为 “知识 魔 呢 ”。 


“我 以 为 我 说 “天 啊 ， 你 们 都 在 说 些 什么 啊 ? ”的 时 候 是 代表 所 有 人 。” 


毫 无 疑问 ， 栽 在 这 个 魔 吕 上 的 正 是 我 们 自己 。 

想象 一 下 ， 向 从 来 没有 接触 过 HTML 或 任何 标记 语言 的 人 解释 
HTML 是 怎么 回 事 。 我 们 会 先 介绍 基本 的 标签 ， 比 如 <p>、<br> 和 
<strong>， 接 下 来 解释 标签 里 的 内 容 如 何 继承 标签 的 属性 ， 然 后 说 
明 每 个 标签 必须 以 相同 的 标签 里 加 上 一 条 和 斜 线 来 结 
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在 大 家 都 频频 点 头 之 后 ， 我 们 会 看 一 段 简单 的 HTML: 
<p> 

Hello world! 

<br /> 


It's a <strong>beautiful day</strong>! 
</p> 


对 我 们 来 说， 这 实在 没什么 好 解释 的 。 这 就 是 一 小 段 话 ， 中 间断 
WMT, SIAL SBR. EYP TER TAKARA CSS 和 浏览 
器 测试 ! 可 能 在 吃 午 饭 前 还 能 讲 讲 jQuery 选择 器 呢 ! 

从 刚刚 接触 标记 语言 的 人 的 角度 考虑 一 下 吧 。 他 们 可 能 会 想到 这 
些 问题 : 

口 为 什么 我 们 把 文字 放 在 <strong> 标 签 行 里 ， 而 不 把 <p> 放 在 

<strong> 标 签 行 里 呢 ? 

口 为 什么 <br> 标 签 的 斜 杠 在 最 后 而 不 是 在 开头 呢 ? 结束 它 的 对 

应 标签 在 哪里 呢 ? 

O 能 在 <strong> 标 签 里 面 再 加 标签 吗 ?” 要 是 把 day 这 个 单词 包 
在 <strong> 里 面 会 怎么 样 呢 ? 会 让 它 变 得 …… 更 粗 吗 ? 

我 们 给 学 生 看 的 这 个 HTML 例子 里 面 充满 了 许多 小 小 的 假定 ， 
根本 没有 想到 这 些 会 是 问题 。 对 于 新 手 来 说 , 每 个 细微 差别 都 要 解释 
清楚 。 不 要 有 假定 ,即使 是 把 一 些 标签 写 在 行内 而 给 另 一 些 标签 换行 
是 为 了 代码 可 读 性 这 个 事实 ， 也 不 能 认为 是 理所当然 的 。 

所 以 ， 当 你 教 新 手 的 时 候 ， 要 把 速度 放 慢 一 倍 。 每 走 一 步 ， 都 要 
考虑 一 下 你 不 自觉 做 的 那些 假定 ,并 把 这 些 “ 显 然 ” 的 东西 作为 知识 
点 来 解释 。 经 常 问 问 你 的 学 生 ， 他 们 是 不 是 能 跟 得 上 。 

当 意 识 到 “知识 魔 响 ”的 重大 影响 之 后 ,你 就 更 能 捕捉 到 那些 可 
能 被 学 生 遗 漏 的 细微 之 处 。 
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第 35 篇 用 浅显 的 例子 


对 于 新 手 来 讲 , 好 的 例子 里 是 没有 抽象 的 东西 的 。 例 子 就 应 该 是 
具体 的 ， 能 够 清晰 地 一 一 哪怕 清晰 得 过 分 了 一 一 传达 想 要 讲授 的 东 
西 ， 而 且 能 够 提供 良好 的 语 境 。 

相反 , 坏 的 例子 里 满 是 抽象 的 概念 和 模糊 的 区 分 。 下 面 就 是 一 个 
经 典 案例 。 


当 清 晰 遇 上 Sally 


想象 一 下 ， 我 们 给 刚 入 门 的 程序 员 讲 面向 对 象 编程 的 基础 知识 。 
我 们 也 许 很 自然 地 就 从 讨论 类 的 构造 函数 和 对 象 实例 化 开始 。 谈 到 某 
个 地 方 的 时 候 ， 我们 随手 写 这 么 一 行 代码 : 

Object myObject = new Object(); 

对 于 我 们 来 说 , 这 就 是 一 行 很 无 聊 的 示例 代码 而 已 。 它 说 的 是 要 
为 类 型 为 Object 的 对 象 创建 一 个 实例 ， 叫 做 my0bject。 我 们 都 知 
道 ，my0bject 只 不 过 是 给 这 个 新 创建 的 实例 随便 起 的 名 字 而 已 。 然 
而 ,构造 函数 0bject () 的 名 字 可 不 能 乱 起 ， 它 必须 得 和 类 的 名 字 完 
全 一 样 。 

我 们 可 以 把 这 些 都 告诉 学 生 。 学 生 可 以 记 笔 记 ， 然 后 温习 一 遍 。 
对 于 一 个 第 一 次 接触 对 象 实例 化 的 人 来 说 , 这 行 看 似 浅显 的 代码 看 起 
来 是 这 样 的 : 

Object myObject = new Object(); 

对 于 刚 上 手 的 人 来 说 ， 很 难 理解 哪个 Object 是 类 型 、 哪 个 是 构 
造 函 数 、 哪 个 是 实例 名 称 。 如 果 把 这 行 代码 遮 起 来 , 然后 让 学 生 重 写 ， 
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那么 即使 他 们 写 出 Object Object() = new myObject; 或 my new 
Object = 0bject() ;之 类 的 ， 你 也 不 要 惊讶 。 

让 我 们 把 这 个 例子 改 得 再 浅显 一 点 。 这 样 重 写 会 好 些 : 

Object sally = new Object(); 

这 样 就 明白 些 了 。0bject 仍然 很 重要 ， 但 很 明显 它 和 对 象 实例 
的 名 称 之 间 并 没什么 联系 。 现 在 也 比较 容易 看 出 , 实例 的 名 称 要 放 在 
类 型 右边 。 

不 过 , 对 于 第 一 次 写 面向 对 象 程序 的 人 来 说 , 这 还 是 有 点 云 里 雾 
里 。 在 我 们 能 够 创建 的 对 象 的 所 有 类 型 里 ， 叫 做 “Object” 的 这 个 很 
可 能 是 最 抽象 的 一 个 。 我 们 还 是 坚持 那个 “避免 不 必要 的 抽象 ”的 原 
则 吧 。 把 这 个 例子 再 改 一 下 ， 让 它 的 名 字 更 有 描述 性 : 


Human sally = new Human(); 

好 啦 ! 现在 Human (A ) 很 说 明 问题 。 对 于 在 这 个 星球 上 生活 的 
任何 人 (即使 不 是 职业 写 程序 的 人 ) 来 说 ，Human 和 sally 之 间 的 
关系 都 是 显而易见 的 。 显 然 ，sally 就 是 我 们 给 Human 的 这 个 实例 
所 选 定 的 名 称 。 

不 过 还 是 有 些 东 西 有 点 难以 理解 。 新 手 的 下 一 个 问题 可 能 是 : 如 
果 我 们 说 “Human Sally”， 那 她 是 一 个 新 的 人 不 是 显而易见 的 吗 ? AS 
构造 函数 到 底 有 啥 用 ? 
不 带 任何 参数 的 构造 函数 在 编程 时 是 很 常见 的 。 经 验 丰富 的 程序 
员 已 经 习惯 了 那些 在 实例 化 时 不 接受 任何 参数 的 类 。 它们 就 是 一 直 不 
带 参数 , 除非 我 们 有 很 好 的 理由 来 加 上 在 构造 时 需要 额外 信息 的 构造 
函数 。 所 以 ,传统 的 new Object() (或 new Human() 或 new 
List<DateTime>()) 对 我 们 来 说 很 直观 。 

但 对 于 新 手 来 说 ， 这 个 看 起 来 很 思春 。 构 造 郴 数 不 接受 参数 ， 而 


7 


z] 
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且 更 糟糕 的 是 , 它们 在 定义 中 除了 实例 化 对 象 之 外 什么 也 不 做 。 这 一 
点 让 很 多 面向 对 象 编程 的 初学 者 感到 困惑 。 所 以 有 时 候 ， 即 使 是 默认 
的 引入 方法 也 不 一 定 是 给 新 手 讲 授 概 念 的 最 好 的 例子 。 在 这 个 例子 
里 ,我 们 要 是 给 示例 构造 函数 加 上 一 个 (或 两 个 ) 参数 就 好 多 了 。 

Human sally = new Human("female", 45); 

问 问 学 生 能 不 能 创建 一 个 叫做 Harry 的 刚刚 拿 到 驾照 的 人 ”， 他 
很 有 可 能 想 出 答案 : 


Human harry = new Human("male", 16); 

展示 例子 的 时 候 , 要 让 它 浅显 易 懂 。 抛 弃 惯 常 的 讲法 ， 换 成 更 明 
确 的 例子 。 去 掉 那 些 泛泛 之 谈 、 通 用 名 称 和 理论 , 换 成 触手 可 得 的 明 
显 的 东西 。 哪 伯 是 对 象 实例 化 这 人 么 基础 的 例子 , 我 们 也 改 了 四 毅 才 至 
于 清晰 。 


D 美国 法 定 的 驾车 年 龄 是 16 周岁 。 一 一 译 者 注 
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当 你 教 一 样 新 东西 的 时 候 , 不 要 认为 你 所 说 的 每 一 句 话 都 必须 是 
百 分 百 正确 的 。 要 把 一 个 概念 从 一 开始 就 讲 得 非常 完美 ， 既 不 现实 ， 
效果 也 不 好 。 高 级 的 概念 本 来 就 比较 难 理解 , 这 也 正 是 它 成 为 高 级 概 
念 的 原因 。 它 充满 各 种 细微 差别 、 例 外 和 特殊 情况 ,不 那么 符合 一 个 
完美 的 统一 理论 的 标准 。 

反 过 来 ,在 学 一 样 新 东西 的 时 候 , 我 们 极度 渴望 的 正 是 那 套 完美 
的 客观 事实 。 我 们 想 要 快速 了 解 真理 ， 而 无 论 它们 是 不 是 真 的 存在 ， 
因为 这 些 东 西 都 会 为 我 们 学 习 任 何 学 科 的 知识 打下 基础 。 

所 以 , 在 你 成 为 专家 之 后 , 要 先 把 你 所 在 领域 中 那些 错综复杂 的 
细 枝 末节 售 掉 。 不 要 讲 那些 “除了 ”和 “但 要 是 ……” 之 类 的 特殊 情 
况 ， 因 为 它们 现在 不 那么 重要 。 一 开始 的 时 候 ， 只 要 介绍 几 条 规则 ， 
让 你 的 学 生 能 够 把 概念 理解 得 差不多 即 可 。 稍微 把 事实 扭曲 一 点 儿 来 
简化 概念 也 没什么 大 不 了 的 。 讲 课 的 时 候 , 善意 的 谎言 并 不 见得 是 件 
坏事 。 

当 我 们 把 一 个 复杂 的 主题 削减 成 不 那么 完美 的 一 套 规则 之 后 , 就 
为 新 手 理解 该 主题 打下 了 坚实 的 基础 。 要 是 在 人 们 还 没完 全 消化 一 般 
概念 之 前 就 急 着 讲 那些 细节 和 例外 ,他们 就 无 法 系统 地 学 习 了 , 他 们 
所 学 的 内 容 就 会 像 是 一 堆 分 散 的 碎片 。 一 下 子 把 碎片 拼 成 全 图 可 不 太 
容易 ， 同 时 消化 规则 和 规则 的 例外 也 是 十 分 困难 。 

比如 ， 当 我 教 别人 数据 库 建 模 的 基础 知识 的 时 候 , 我 开始 时 的 理 
念 总 是 : 一 个 好 的 关系 型 数据 库 应 该 是 完全 规范 的 ， 毫 无 例外 。 根 据 
我 的 “ 张 氏 定律 ”， 任 何 两 张 表 都 不 应 有 元 余 的 数据 。 

在 现实 中 ， 确 实 存在 需要 让 数据 库 去 规范 化 的 情况 。 比 如 说 ， 
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OLAP 数据 立方 "就 是 一 种 打破 了 数据 库 规范 化 这 一 传统 规则 的 数据 
库 , 它 允许 出 现 匈 余数 据 。 去 规范 化 的 数据 库 可 以 遍历 更 少 的 表 ， 进 
行 更 少 的 关系 型 联结 (JOIN ) 操作 ,从 而 让 复杂 搜索 查询 的 速度 大 大 
提高 。 然 而 , 新手 在 一 开始 根本 就 不 应 该 关心 这 个 问题 ,应 该 等 到 他 
完全 了 解 了 规范 化 的 好 处 之 后 再 说 。 要 了 解 地 基 中 的 裂缝 , 他 首先 得 
透彻 地 了 解 这 个 地 基 。 
所 以 , 要 是 最 初 的 理解 不 是 百 分 百 正确 会 怎么 样 呢 ? 坚实 的 基础 
会 给 人 以 动力 ， 而 这 个 动力 会 让 学 生 更 快 地 达到 高 级 阶段 。 


D 参见 http://en.wikipedia.org/wiki/OLAP_cube。 
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就 像 我 在 前 一 篇 里 面谈 到 的 , 讲授 规则 的 时 候 要 把 它们 当成 坚 不 
可 挫 的 自然 法 则 。 这 为 新 手提 供 了 一 个 系统 的 出 发 点 。 要 想 让 学 生 达 
到 专家 水 平 , 到 了 某 个 时 候 , 就 需要 撤 掉 其 辅助 轮 。 一旦 基础 打 好 后 ， 
学 生 就 可 以 开始 逐步 偏离 规则 了 ,辅助 轮 、 护 膝 、 自 行车 头盔 也 都 可 
以 不 用 了 。 

德 雷 福 斯 学 习 模 型 就 提倡 这 一 点 。" 简 而 言 之 ， 德 雷 福 斯 模型 就 
是 一 个 描述 学 生 如 何 学 习 的 模型 ,这 是 1980 年 由 一 对 博士 兄弟 ( Stuart 
和 Hubert Dreyfus ) 在 加 州 大 学 伯克利 分 校 做 研究 时 提出 的 。” 

当 开 始 掌握 编程 等 学 科 的 时 候 , 就 不 再 通过 分 析 规 则 来 指导 工作 
了 ,因为 这 已 经 变 得 自然 而 然 了 。 我 们 的 思维 会 变 得 更 为 抽象 。 我 们 
会 想 出 多 种 方法 来 实现 同样 的 功能 目标 。 用 不 着 什么 秘诀 了 , 一 切 都 
赁 直觉 。 当 学 生 也 开始 赁 直觉 的 时 候 ， 我 们 就 知道 自己 教 得 不 错 了 。 
我 们 要 鼓励 这 种 自主 思维 。 

怎么 才能 做 到 这 一 点 呢 ? 过 一 阵子 之 后 , 你 就 会 发 现 学 生 的 技术 
问题 越 来 越 少 , 而 策略 问题 开始 增多 。 这 就 是 他 们 已 经 掌握 了 “如 何 ” 
和 “什么 ”并 开始 琢磨 “为 什么 ”的 第 一 个 标志 。 当 他 们 开始 问 “ 为 
什么 ”的 时 候 , 通常 意味 着 他 们 觉得 有 更 好 的 方法 ， 而 你 所 教 的 东西 
限制 了 他 们 快速 形成 的 自然 直觉 。 

要 一 直 鼓 励 这 种 思维 过 程 , 不 要 一 上 来 就 把 它 拍 死 。 让 他 们 再 想 
出 一 种 方法 ,然后 分 析 其 优 缺 点 。 要 是 某 种 方法 有 明显 的 优势 ， 就 带 


yw 


a: 


@D 参见 http://en.wikipedia.org/wiki/Dreyfus_model_of skill acquisition. 
Q 要 深入 了 解 这 个 模型 ， 请 参阅 Andy Hunt 的 书 《 程 序 员 的 思维 修炼 》( Pragmatic 
Thinking and Learning ) [Hun08]。 
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领 学 生 透 彻 地 分 析 其 欠 优 的 情况 ， 让 他 们 了 解 在 哪里 可 能 会 出 问题 。 
接 下 来 , 他 们 提出 的 方法 可 能 会 越 来 越 有 说 服 力 。 到 了 菜 个 时 候 ， 
你 甚至 可 能 让 他 们 自己 来 做 出 选择 。 也 许 有 一 天 , 你 教 过 的 学 生 在 教 
你 。 这 并 不 意味 着 你 输 了 一 阵 ， 而 是 证 明 你 真正 学 会 了 教学 。 
ERER, 我 们 谢 析 了 教学 的 过 程 : 引导 编程 学 徒 理 解 我 们 头脑 
中 的 东西 。 
把 我 们 的 方式 教 给 客户 也 同样 是 很 有 益处 的 。 下 一 章 里 , 我们 会 
谈 一 谈 为 什么 教学 能 让 我 们 和 付 钱 的 主 顾 之 间 的 关系 更 为 健康 。 
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在 我 们 这 一 行 ,客户 是 我 们 的 生命 线 。 没 有 客户 ， 我 们 做 的 东西 
到 最 后 也 无 非 是 自 娱 自 乐 轻 了 。 

但 是 ， 很 多 时 候 ， 我 们 和 客户 之 间 的 工作 关系 不 像 是 合作 伙伴 ， 
倒 像 是 对 手 。 在 理想 的 世界 里 ， 当 我 们 挥汗如雨 时 ,客户 一 边 给 我 们 
揉 揉 肩膀 , 一 边 把 香草 冰淇淋 送 到 我 们 嘴 边 ,同时 还 不 忘 了 帮 我 们 擦 
擦 嘴角 。 在 理想 的 世界 里 , 客户 能 够 理解 我 们 在 把 想法 变 成 代码 的 过 
程 中 时 常 经 受 的 痛苦 。 

但 残酷 的 现实 是 , 客户 很 少 能 够 看 到 我 们 为 了 迎合 不 断 变化 的 需 

求 而 经 受 的 痛苦 。 客 户 只 会 考虑 他 们 想 要 的 那个 新 功能 一 一 那个 在 他 
们 眼中 “只 需 改 这 一 点 点 ”， 可 实际 上 却 要 大 动 干戈 的 功能 。 而 利益 
相关 方 关 心 的 只 是 租 亏 而 已 。 
其 实 这 还 好 啦 。 和 所 有 关系 一 样 ， 客户 和 程序 员 之 间 关 系 的 培养 
也 是 一 个 渐进 的 过 程 。 要 是 双方 都 能 理解 对 方 注重 的 东西 , 关系 就 会 
变 好 。 要 和 客户 好 好 合作 , 首先 要 站 在 他 们 的 立场 看 问题 ， 然 后 再 告 
诉 他 们 ， 我 们 这 边 是 怎么 运转 的 。 
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我 们 很 容易 抱怨 客户 太 难 绰 , 但 是 请 记 住 , 这 种 问题 并 不 是 只 有 
我 们 才 会 遇 到 。 事 实 上 ， 和 其 他 一 些 人 比 起 来 ， 我 们 要 好 得 多 了 。 

当 建 筑 师 设计 一 所 房子 的 时 候 , 业主 只 会 看 到 那些 很 容易 看 到 的 
东西 。 她 看 到 的 是 那些 外 在 的 品质 一 一 花岗岩 台面 、 人 硬木 地 板 、 天 花 
线 一 一 而 不 是 建筑 师 哎 心 沥 血 几 个 月 才 绘 制 出 的 设计 图 的 精妙 之 处 。 

要 是 大 厨 做 菜 时 多 放 了 一 勺 盐 , 挑剔 的 客人 会 抬杠 般 地 把 荣 退 回 
去 ， 而 大 厨 的 作品 就 会 因此 变 得 一 文 不 值 ， 只 能 倒 进 垃圾 桶 。 我 曾经 
见 过 趾 高 气 扬 的 一 家 人 ， 他 们 因为 十 几 岁 的 儿子 在 饭 里 看 到 了 一 只 毛 
昔 昔 的 虫子 后 没 了 胃口 ， 就 把 整 桌 荣 肴 退回 厨房 。 整 班 厨 师 辛勤 劳作 
的 作品 就 这 样 被 扔 掉 ， 只 是 因为 顾客 把 一 块 露出 纤维 的 痿 当成 了 蜂 螂 。 

我 们 都 当 过 顾客 。 顾 客 很 少 会 欣赏 他 们 消费 的 产品 里 那些 精致 、 
巧妙 的 构思 。 这 就 是 残酷 又 讽刺 的 现实 。 我 要 是 雇 了 个 管道 工 来 解决 
淋浴 器 水 压 太 低 的 问题 ,我 想 的 就 是 赶紧 修好 。 我 不 关心 到 底 是 主线 
路 问题 、 限 流 器 问题 ， 还 是 喷头 墙 了 。 只 要 要 价 不 高 ， 能 让 我 舒 舒服 
服 地 洗澡 就 行 了 ， 谢 谢 。 

我 们 给 顾客 或 客户 做 软件 的 时 候 也 是 一 样 的 道理 。 他 们 很 可 能 不 
懂得 欣赏 我 们 编 的 软件 有 多 么 优雅 ， 多 么 精巧 。 

这 意味 着 什么 呢 ? 这 意味 着 我 们 的 主 顾 没 人 关心 代码 , 至 少 不 是 
直接 关心 代码 。 这 还 意味 着 ， 要 我 们 改动 软件 的 时 候 ， 他 们 全 然 不 知 
修改 这 个 代码 是 易 是 难 , 是 根本 不 可 能 还 是 让 人 恼火 。 他 们 不 知道 那 
个 “加 上 也 许 不 错 ” 的 功能 是 不 是 “ 编 起 来 会 令 人 崩溃 ”。 

这 挺 让 人 郁闷 的 ， 确 实 如 此 。 但 不 要 顾 影 自 怜 ， 因 为 郁闷 的 人 不 
止 你 一 个 。 
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那 我 们 如 何 让 客户 欣赏 我 们 的 劳动 呢 ? 

有 时 候 , 要 告诉 客户 我 们 是 如 何 完成 我 们 的 工作 的 , 尤其 要 告诉 
那些 从 未 自己 开发 过 软件 的 客户 。 即使 在 我 们 看 来 是 完全 显而易见 的 
事情 , 对 于 其 他 人 来 说 也 并 不 是 常识 。 从 业 以 来 , 我 已 经 经 历 了 很 多 
次 这 样 的 教训 了 。 

许多 年 前 , 我 接 了 一 个 零 活 ,给 客户 做 一 个 在 线 推荐 系统 。 当 时 
我 22 岁 ， 还 是 个 编程 新 手 ， 那 个 项 目 听 起 来 很 简单 。 该 软件 会 做 一 
个 数据 库 搜索 ， 给 酒吧 和 和 餐馆 的 酒 类 批发 提供 最 低 的 报价 。 

这 再 简单 不 过 了 。 

一 个 周末 的 下 午 , 我 和 客户 在 一 个 咖啡 迄 碰 头 来 讨论 细节 。 我 以 
为 我 会 拿 到 一 张 井 井 有 条 的 表格 ， 里 面 有 我 要 的 数据 一 一 酒 的 品种 、 
品牌 、 分 销 商 、 地 址 和 成 本 。 用 户 要 查询 某 一 种 酒 ， 点 击 搜索 按钮 ， 
然后 软件 就 会 在 系统 中 找 出 符合 输入 的 搜索 参数 的 最 低 价格 。 这 听 起 
来 棒 极 了 。 我 的 客户 和 我 都 同意 了 这 个 做 法 ,然后 各 自分 头 行动 。 他 
负责 整合 数据 ， 我 则 开始 开发 这 个 简单 、 优 雅 的 精致 软件 的 典范 。 

根据 我 们 前 些 天 初次 会 谈 的 安排 , 我 差不多 花 了 一 个 星期 把 软件 
的 基础 搭 好 了 。 于 是 一 周 之 后 ,我们 一 起 吃 午饭 来 看 看 他 整理 的 Excel 
表格 。 他 的 表格 比 我 想象 的 要 复杂 点 儿 , 不 是 我 预计 的 那 种 简单 的 五 
列表 格 。 我 咬 了 咬 嘴唇 ， 局 促 地 笑 了 笑 。 

“你 看 ,价格 是 随 着 购买 量 而 变化 的 。” 我 的 客户 说 。 还 有 男 外 两 
列 : 针对 某 个 特定 价格 ,必须 购买 的 最 大 和 最 小 数量 。 

WIE, 我 想 。 毕竟 这 就 是 批量 采购 的 目的 所 在 嘛 。 我 回 到 白板 前 ， 
把 数据 模型 稍稍 改动 了 几 处 , 行 了 。 
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第 二 天 我 就 有 了 解决 方案 。 我 在 数据 库 里 又 加 了 两 个 字段 : 
BeginRange 和 EndRange。 我 把 软件 改 了 一 下 ， 让 它 可 以 接受 数量 ， 
然后 调整 了 SQL 查询 语句 ， 这 样 就 可 以 筛选 出 满足 
@quantity>=BeginRange H.@quantity<=EndRange 的 记录 。 这 系 
统 又 变 得 完美 了 ! 

我 们 第 三 次 碰面 的 时 候 , 客户 似乎 有 点 儿 困 惑 。 我 的 代码 很 漂亮 ， 
但 系统 的 行为 似乎 缺 了 些 什么 。 我 们 试 着 用 了 用 这 个 软件 ,他 发 现 还 
少 了 几 个 开关 。 

我 很 快 发 现 , 在 实际 情况 中 , 如 果 客 户 把 相似 的 产品 绑 在 一 起 购 
买 可 以 拿 到 折扣 。 批 量 采购 的 概念 并 不 光 适 用 于 单个 产品 ， 比 如 ， 购 
KT X 件 威士忌 可 能 会 让 你 在 购买 Y 件 苗 艾 酒 时 拿 到 折扣 (有 人 要 
喝 曼哈顿 鸡尾酒 吗 ? )。 此 外 , 折扣 的 幅度 还 取决 于 你 买 多 少 威士忌 。 
我 们 可 能 还 应 该 免费 赠送 几经 马 拉 斯 奇 诺 楼 桃 呢 。 

从 他 的 角度 来 看 ， 这 个 系统 的 反应 是 不 对 的 。 根 据 他 的 经 验 , 通 
过 直接 给 分 销 商 本 人 打 电 话 而 拿 到 这 些 折扣 是 很 平常 的 一 件 事 。 但 从 
我 的 角度 来 说 ， 我 根本 没有 能 够 推导 出 这 些 东 西 的 数据 或 者 条 件 逻 
辑 。 另 外 ， 就 算 他 能 够 提供 我 需要 的 所 有 数据 ,我 还 得 花 很 多 时 间 来 
搞 清楚 如 何 组 织 这 些 数据 。 我 需 不 需要 再 建 些 存储 依赖 关系 的 表格 ， 
来 处 理 因 购买 其 他 产品 而 产生 的 折扣 呢 ? 我 要 不 要 搞 一 个 “常见 混合 
搭配 ”的 功能 ,以 便 软 件 预知 顾客 可 能 购买 哪些 产品 来 获得 其 他 折扣 
呢 ? 最 重要 的 是 ， 在 这 之 后 还 会 不 会 出 现 更 多 让 人 抓 狂 的 模型 呢 ? 

有 一 天 , 我 突然 明白 过 来 , 我 不 是 在 制作 一 个 通过 挖掘 数据 表 来 
找 出 单个 正确 答案 的 简明 清晰 的 系统 ， 而 是 在 制作 一 个 名 叫 Larry™ 
的 酒 类 分 销 经 理 。 我 在 努力 作出 那些 无 法 轻易 推断 出 的 决策 。Larry™ 
能 够 基于 他 和 客户 之 间 的 关系 、 他 四 十 年 的 从 业经 验 , 再 加 上 点 第 六 
感 来 提供 报价 。 他 知道 怎样 让 客户 成 为 回头 客 ,， 从 而 胜 过 与 他 竞争 的 
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男 外 一 百 个 分 销 商 。 

为 哈 一 开始 没 人 告诉 我 所 有 这 些 信息 呢 ? 我 的 客户 是 成 心 不 告 
诉 好 奇 心 重 的 我 ， 还 是 他 自己 当时 也 不 知道 这 些 很 重要 呢 ? 

现在 , 很 多 非 技术 人 员 都 对 软件 存在 一 个 很 基本 的 误解 。 作 为 程 
序 员 ,我 们 基本 上 是 逻辑 和 信息 的 整理 者 ,我 们 的 工作 主要 是 推送 、 
接收 、 人 处理 和 显示 数据 。 我 们 中 大 部 分 人 搞 的 都 不 是 人 工 智能 。 我 们 
没 法 轻易 地 写 出 能 够 推荐 或 猜测 的 程序 ， 即 使 “推荐 ”或 “猜测 ”是 
一 些 预 定好 的 、 可 以 描述 的 逻辑 。 然 而 有 时 候 ， 在 外 行人 的 想象 中 我 
们 的 工作 方式 是 这 样 的 : 有 某 种 黑 魔法 盒 , 即使 我 们 不 给 出 所 有 的 信 
息 ， 它 也 能 理 清 所 有 的 头绪 。 

当 我 开始 向 客户 解释 我 所 开发 的 软件 和 他 所 要 的 软件 之 间 的 区 
别 时 , 我 的 客户 说 他 会 给 我 答复 的 。 多 年 过 去 了 , 我 的 代码 仍然 沉睡 
在 那个 被 我 爱 称 为 集 尘 器 /镇 纸 石 的 旧 笔 记 本 里 。 

回 过 头 来 看 , 我 更 清楚 地 了 解 了 客户 和 程序 员 之 间 的 关系 。 在 我 
的 客户 看 来 ，Web 、 软 件 、 数 据 库 …… 所 有 这 些 “ 技 术 ” 的 东西 都 是 
一 团 神秘 的 魔法 云 。 他 在 潜意识 中 相信 代码 能 够 神奇 地 处 理 一 些 没 有 
定义 的 逻辑 , 尽管 这 些 没有 交代 的 东西 正 是 让 此 类 软件 编写 起 来 无 比 
复杂 的 原因 。 

在 任何 项 目 里 都 会 有 一 些 未 知 的 东西 ， 这 就 是 我 们 的 工作 性 质 。 
转 入 开发 的 时 候 , 很 少 会 有 一 个 想法 能 够 完全 清楚 地 陈述 出 来 ,而 且 ， 
就 算 所 有 人 都 觉得 它 很 清楚 了 , 实际 上 也 不 是 这 样 。 在 软件 仅仅 停留 
在 口头 上 的 时 候 , 怪 蜡 的 地 方 总 能 够 逃 过 我 们 的 思维 ,直到 我 们 开始 
动手 写 的 时 候 它 才 鬼 鬼 持 洪 地 揭 开 自己 的 面纱 。 

可 能 这 就 是 我 们 和 客户 之 间 爱 恨 交 织 的 原因 。 有 些 事情 在 我 们 这 
些 在 “黑箱 内 部 ” 饱 受 折磨 的 人 看 来 再 明显 不 过 , 可 外 部 的 人 却 毫 不 
知情 ,因为 想法 的 真正 实现 都 是 在 箱子 里 面 进行 的 。 我们 对 箱子 里 面 
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的 事情 了 如 指 掌 , 知道 里 面 是 不 是 有 具体 的 东西 ， 而 真正 的 痛苦 和 挣 
扎 也 都 在 箱子 内 部 。 
外 部 人 的 挫折 感 也 来 源 于 此 。 从 他 们 的 角度 看 ,他们 已 经 给 了 你 
很 多 信息 啊 , 要求 啊 ， 细 节 啊 一 一 肯定 足够 你 开工 了 。 他 们 告诉 我 们 
想 要 什么 ， 然 后 就 开始 等 待 …… 


接 下 来 ， 几 天 、 几 周 或 者 几 个 月 以 后 ， 如 果 他 们 看 到 的 东西 不 是 
他 们 想 要 的 , 他 们 也 会 感到 泄气 ,因为 这 个 箱子 并 没有 他 们 想象 的 那 
么 神奇 。 

出 现 这 种 情况 的 时 候 ， 把 你 的 客户 带 到 “箱子 ”里 。 如 有 需要 ， 
早点 儿 把 他 们 带 进 来 ， 告 诉 他 们 你 们 都 做 了 些 什 么 工作 。 必 要 的 话 ， 
带 他 们 看 看 实际 的 代码 , 让 他 们 也 思考 一 下 你 在 编程 时 自然 而 然 想到 
的 那些 问题 。 
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和 客户 一 起 工作 不 是 件 容易 的 事 。 你 〈 程序 员 / 设 计 师 /救世 主 ) 
和 他 们 (有 了 时 是 不 可 理喻 的 独裁 者 ) 之 间 的 脱节 永远 是 存在 的 。 

但 不 是 所 有 的 客户 都 不 易 相 处 。 比 较 好 的 客户 ,那些 我 们 在 整个 
咨询 生涯 中 都 不 愿意 丢掉 的 客户 , 那些 我 们 希望 总 能 有 新 的 项 目 和 新 
的 想法 并 会 随时 告诉 我 们 的 客户 ， 似 乎 都 有 一 个 共同 的 特点 。 

好 的 客户 把 软件 置 于 他 们 自己 之 上 。 如 果 软 件 是 项 目 中 最 重要 的 
部 分 , 那么 其 他 的 东西 自然 而 然 就 理 顺 了 。 每 个 关于 功能 的 决定 都 可 
以 用 这 个 简单 的 问题 来 检验 :“ 这 个 功能 会 让 软件 变 得 更 好 吗 ?” ” 感 
觉 和 个 人 目的 ,无论 是 我 们 的 还 是 客户 的 ， 都 不 能 左右 结果 。 如 果 
不 是 把 产品 放 在 第 一 位 , 客户 就 会 用 其 他 的 方式 来 证 明 他 的 功能 要 求 
合理 : 

口 “…… 这 个 是 我 在 其 他 网 站 上 看 到 的 ， 很 酷 。” 
口 “…… 因 为 现在 是 1996 年 了 ， 所 有 人 都 在 用 <bLink> 和 计数 


口 “ee 因为 现在 是 2005 年 了 ， 所 有 人 都 在 用 RSS。” 
口 “ee 因为 现在 是 2009 年 了 ， 所 有 人 都 有 一 个 Facebook 和 


Twitter 标签 。” 

O “eee 因为 那 本 讲 可 用 性 的 书 告诉 我 , WER TARRA 
会 读 到 !” 

Q “ene 为 我 们 CEO 喜欢 粉色 1” 


在 刚刚 接触 客户 的 时 候 , 就 把 软件 的 目标 设 定好 ， 和 客户 一 起 确 
定 最 终 产 品 要 达到 什么 效果 ， 然 后 把 它 记 下 来 。 这 样 就 会 让 “ 酷 ” 和 
“尖端 ”之 类 的 子弹 哑 火 。 设 定好 目标 会 让 你 在 说 “不 ”时 更 有 信心 。 
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非 程 序 员 对 于 编程 的 一 大 误解 就 是 编程 完全 是 关于 算法 的 , 但 我 
们 知道 它 不 是 这 样 的 。 编程 的 艺术 性 一 点 也 不 撑 于 其 科学 性 。 我 们 对 
编程 工作 的 热情 丝毫 不 逊 于 艺术 家 对 其 工作 的 热情 。 

我 们 需要 让 非 程 序 员 认 识 到 这 一 点 , 这样， 我 们 就 可 以 改变 和 客 
户 之 间 的 关系 。 开 发 不 只 是 一 项 服务 ， 而 我 们 也 不 只 是 编制 软件 的 
TE, 

让 你 的 客户 看 看 你 工作 中 精巧 的 细节 吧 。 不 要 只 是 草草 给 出 几 个 

解决 对 方 问题 的 选项 , 而 要 在 给 出 这 些 选 项 的 同时 , 表明 你 对 其 中 一 
个 很 有 信心 , 然后 解释 为 什么 。 当 客户 能 够 通过 哪怕 最 俗套 的 选项 看 
到 你 的 热情 时 , 他们 就 更 可 能 在 与 你 意见 相左 时 选择 相信 你 , 并 且 会 
把 你 看 做 你 所 在 领域 的 专家 。 
其 他 行业 的 人 如 何 让 自己 的 作品 吸引 消费 者 的 兴趣 呢 ? 我 们 很 
容易 想到 “原味 主 厨 ” 杰 米 ， 奥利弗 (Jamie Oliver )， 他 推广 了 英 式 
庆 饪 、 健 康 饮食 和 手工 将 所 有 食材 碾 在 一 起 的 做 法 。 我们 还 可 以 谈 谈 
音乐 家 杰克 : 怀特 ( Jack White )， 他 在 戴 维 斯 . 古 根 海 姆 ( Davis 
Guggenheim ) 的 摇滚 吉他 纪录 片 《吉他 英雄 》( I Might Get Loud ) 中 
谈 到 了 他 血 染 的 吉他 。 这 很 有 意思 , 因为 豪 饪 和 音乐 都 直接 触 磁 你 的 
感官 ， 而 且 人 们 一 般 都 愿意 听 名 人 讲 自己 的 技艺 。 

不 过 ， 让 我 来 谈 谈 几 个 不 那么 出 名 的 人 物 吧 。 

pas 曼 弗 雷 迪 尼 (Lou Manfredini ) 被 人 们 称 为 “修理 先生 ”。 他 
是 一 个 精力 充沛 的 乒 人 ,对 与 修理 房子 有 关 的 一 切 都 了 如 指 掌 。 他 每 
周 都 参加 芝加哥 电台 节目 ， 帮 助 业主 处 理 各 种 各 样 的 问题 。 无 论 是 安 
装 新 的 暧 通 空 调 , 修理 漏 雨 的 屋顶 , 还 是 封闭 露台 ， 曼 弗 雷 迪 尼 对 任 
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何 问题 都 能 提出 建议 和 看 法 。 他 很 关心 你 在 儿童 房 中 使 用 哪 种 类 型 的 
油漆 ,还 愿意 帮 你 把 地 下 室 的 害虫 除 净 。 

曼哈顿 的 杰 弗 里 + 鲁 哈 尔 特 ( Jeffery Ruhalter ) 是 第 四 代 诡 丁 传 
人 。 如 果 屠 室 不 会 让 你 反胃 的 话 ， 就 去 看 看 他 是 如 何 分 解 一 头 猪 "或 
是 切割 一 块 风干 的 牛排 ?的 吧 。 他 独特 的 沟通 风格 洋溢 着 热情 ， 他 提 
出 的 建议 你 肯定 坚信 不 疑 。 你 毫 无 疑问 会 觉得 他 的 工作 很 有 趣 〈 除非 
KA AFAR GREY AK )。 

jp Fay TH JE ASG PE HR AN hs Eb E ELLE 
变 得 吸引 人 。 他 们 是 这 些 看 似 乏味 的 行当 中 的 英雄 , 我 们 也 能 成 为 软 
件 领域 的 英雄 。 此 外 ， 我 相信 编程 比 修 漏水 的 水 槽 更 有 趣 些 。 


沙 


见 http://www.youtube.com/watch?v=kA7-KCBPvss。 
参见 http://www. youtube.com/watch?v=rQiFEhsmOCk. 
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充满 热情 的 程序 员 比 较 易 既 。 因 不 成 熟 的 想法 和 功能 实现 而 与 客户 
争辩 , 实在 是 让 人 郁 闽 。 在 我 们 写 出 代码 之 前 ,常常 所 有 想法 都 是 有 关 
图 表 、 功 能 说 明 、 线 框图 的 ,存在 于 那些 号 称 “点子 王 ”的 脑海 里 。 可 
我 们 才 是 那些 执行 把 想法 变 成 现实 这 一 艰巨 任务 的 人 , 且 不 说 这 个 工作 
还 经 常 得 不 到 欣赏 , Bug 只 存在 于 代码 里 , 餐巾 上 的 涂鸦 里 永远 不 会 有 。 

多 年 以 前 ， 软 件 是 让 人 望 而 生 芋 的 命令 行 工具 ， 只 有 电脑 狂人 、 
书 呆 子 和 怪人 才 会 使 用 , 而 写 它 们 的 是 那些 更 狂 的 狂人 、 更 采 的 采 子 
和 更 怪 的 怪人 。 那 个 时 候 ， 当 这 种 孤僻 的 、 坏 脾气 的 、 让 人 生 厌 的 人 
也 许 没什么 。 

WS, 客户 就 是 普通 人 , 不 是 男 外 一 批 搞 软件 的 。 他 们 使 用 我 们 
的 劳动 产品 就 像 使 用 家 具 一 样 , 很 自然 的 。 使 用 软件 的 场合 和 不 使 用 
软件 的 场合 之 间 的 界限 很 模糊 了 。 技 术 现在 是 主流 行业 了 。 

这 就 意味 着 我 们 得 根据 软件 的 目标 用 户 调整 我 们 的 工作 方式 。 当 
一 个 还 不 太 了 解 我 们 工作 方式 的 客户 提出 是 否 可 以 加 上 一 个 功能 时 ， 
如 果 这 样 会 打破 已 经 约定 好 的 前 提 ,， 甚至 颠覆 整个 软件 架构 , 我 们 很 
容易 就 会 迅速 作出 反击 。 

不 要 这 样 ， 要 宽容 。 在 趴 在 引擎 盖 下 埋头 若干 的 时 候 ， 也 要 理解 
劳 人 的 看 法 。 如 果 客 户 的 要 求 不 切实 际 ， 就 向 他 们 好 好 解释 ,给 他 们 
一 个 例子 ， 让 他 们 看 看 会 “放出 一 屋子 虫子 ”的 情况 ,并 提供 一 个 变 
通 方法 来 解决 他 们 的 问题 。 

此 外 ,要 养 成 和 他 们 谈话 的 习惯 。 听 听 他 们 真实 的 声音 ,也 让 他 
们 听 听 你 的 声音 。 拿 起 电话 打 给 他 们 , 不 要 只 发 邮件 。 你 会 惊讶 地 发 
现 ， 一 个 体贴 的 声音 能 给 你 带 来 很 大 的 转机 。 
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我 们 的 工作 对 客户 来 说 值 多 少 钱 呢 ? 

当 我 们 估算 一 个 项 目的 价值 的 时 候 ， 基 本 上 是 按照 行业 标准 , 也 
就 是 仅仅 按照 花费 的 时 间 来 计算 。 我 们 猜测 一 下 做 这 个 项 目 大 致 需要 
多 少时 间 ， 再 加 上 点 不 确定 性 的 裕 量 , 乘 上 每 小 时 的 价格 ， 然 后 希望 
在 交 给 客户 之 前 , 这 个 最 终 估价 看 起 来 还 算 差 不 离 。 这 里 面 的 武断 之 
处 实在 让 人 不 太 满 意 。 

工作 200 个 小 时 就 该 比 工作 100 个 小 时 贵 上 一 倍 吗 ? 所 有 人 ,从 
个 体 合 同 工 到 市 值 几 百 万 美元 的 开发 工作 室 ， 都 是 按照 小 时 计 费 的 。 

这 就 是 我 们 评价 工作 价值 的 合理 方式 吗 ? 我 们 花 在 咨询 、 设 计 、 
开发 、 调 试 和 测试 上 的 时 间 真 的 能 和 它 的 价值 画 等 号 吗 ? 我 认为 不 
能 。 但 很 不 幸 ， 这 就 是 世界 上 大 多 数 地 方 采用 的 唯一 衡量 标准 。 

在 很 多 公司 , 时间 记 录 就 等 于 员工 对 业务 的 价值 。 他们 美 其 名 日 
员工 利用 率 。 我 们 向 客户 收费 的 小 时 数 越 多 ， 我 们 的 利用 率 就 越 高 。 

但 这 一 切 完 全 忽视 了 所 有 程序 员 珍 惜 的 那些 时 刻 , 那些 在 开发 过 
程 中 突然 灵光 闪现 、 想 出 更 好 解决 方案 的 时 刻 。 有 了 天 才 想 法 ,我 们 
只 用 两 个 小 时 就 解决 了 起 初 估 计 需 要 八 个 小 时 的 问题 。 更 棒 的 是 , 我 
们 的 解决 方式 比 最 初 规划 的 具有 更 好 的 扩展 性 。 太 赞 了 1 

等 等 ,等 一 下 。 把 香槟 放下 。 现 在 我 们 得 用 更 多 的 客户 工作 来 填 
满 那 多 出 来 的 六 个 小 时 了 一 一 如 果 有 的 话 , 不 然 我 们 的 利用 率 数据 就 
该 往 下 掉 了 。 

在 这 种 公司 里 , 对 程序 员 价 值 的 衡量 仅仅 是 计算 解决 问题 时 合理 
用 掉 的 小 时 数 , 而 不 是 衡量 程序 员 真正 创造 的 价值 ， 因 此 创造 性 思维 
就 得 不 到 任何 激励 。 所 以 ,我 们 还 不 如 就 好 好 遵守 这 个 规则 ， 填 满分 
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配给 我 们 的 每 一 秒 钟 ,也 用 不 着 去 琢磨 更 为 优雅 的 解决 方案 。 在 这 种 


公司 里 , 大 多 数 程序 员 都 打消 了 他 们 要 更 高 效 工 作 的 积极 公 
能 正当 地 提高 他 们 的 利用 率 。 


E ,这样 才 


仅仅 按照 时 间 来 计算 成 本 时 ,我 们 就 把 软件 的 价值 ( 以 及 我 们 提 
供给 客户 的 服务 的 价值 ) 等 同 于 我 们 开发 这 个 软件 所 花 的 时 间 。 
在 我 看 来 ,这 根本 就 不 是 同一 个 指标 , 这 两 个 指标 的 最 终 目 标 截 


然 不 同 。 
我 们 工作 的 价值 还 体现 在 其 他 地 方 


从 客户 的 角度 来 说 ,很 多 其 他 的 指标 都 能 体现 价值 。 
数 例 : 


这 里 仅 举 


灵活 性 

大 多 数 客户 一 一 说 错 了 一 一 所 有 客户 都 不 可 能 一 开始 就 明 
确 地 知道 他 们 想 要 什么 。 无 论 是 功能 还 是 字体 , 客户 都 需要 在 屏 
幕 上 看 到 之 后 , 才能 知道 什么 行 什么 不 行 。 我 们 越 能 够 在 中 途 灵 
活 调整 软件 开发 的 方向 , 就 越 能 够 提供 更 多 的 价值 。 这 对 于 客户 
来 说 非常 有 价值 , 对 于 那些 对 软件 这 种 工具 不 太 熟 悉 的 客户 来 说 
更 是 如 此 。 
教育 

我 们 和 客户 一 起 工作 的 时 候 , 实际 上 是 在 教 他 们 。 他 们 会 了 
解 Web 中 的 种 种 细节 (浏览 器 、 网 络 数据 分 析 、 搜 索引 擎 优化 等 ) 
以 及 我 们 作为 程序 员 所 面临 的 挑战 (这 如 何 能 够 适应 数据 模型 
WE? 怎样 才能 创造 好 的 用 户 体验 呢 ? ) 在 项 目 完 成 的 时 候 , 他 们 
会 比 最 初时 对 软件 拥有 更 为 深刻 的 理解 。 这 本 身 就 是 价值 所 在 。 
亲和力 

如 果 我 们 打 电 话 时 和 欧 可 亲 , 沟通 时 口 吐 莲花 , 客户 就 会 觉 
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得 他 们 雇 的 人 很 好 。 这 也 是 价值 。 
专业 知识 
在 我 的 公司 , 我 们 同时 通过 工作 方式 和 使 用 的 产品 来 推进 流 
程 。 我 们 有 自己 的 看 法 。 客 户 找到 我 们 的 时 候 ,， 常 党 是 想 要 我 们 
提供 答案 和 建议 。 我 们 对 自己 的 看 法 上 毫 不 退让 ， 这 也 是 价值 。 
速度 和 准时 
价值 不 也 应 该 等 同 于 速度 吗 ? 如 果 我 们 可 以 用 最 开始 预计 
的 一 半 时 间 来 完成 一 个 软件 , 为 什么 我 们 得 到 的 报酬 也 要 减 半 ? 
时 间 可 以 作为 内 部 指标 
既然 有 这 么 多 其 他 的 因素 都 会 影响 价值 , 那 应 该 把 时 间 摆 在 哪里 
呢 ? 时 间 也 是 一 个 关键 的 指标 ， 但 应 当 用 它 来 判断 公司 或 个 体 合同 
工 的 工作 是 否 合理 ， 而 不 是 衡量 工作 的 价值 。 时 间 记 录 可 以 回答 这 
类 问题 : 


O 我 们 以 小 组 和 以 个 人 为 单位 的 工作 量 是 否 平衡 呢 ? 


口 在 保证 工作 质量 的 前 提 下 ， 我 们 还 能 接 多 少 工作 ? 
按 产 品 而 不 是 按时 间 收 费 


ABA, 如果 不 用 时 间 的 话 , 我 们 该 如 何 给 一 个 项 目 以 及 我 们 为 这 
个 项 目 提 供 的 服务 定价 呢 ? 要 是 没 能 把 整个 行业 变 成 华尔街 股票 市 
场 那样 ， 由 大 家 集体 决定 服务 X 或 产品 Y 今 天 值 多 少 钱 ， 我们 该 如 
何 做 呢 ? 

一 种 方法 是 把 客户 工作 变 成 一 组 产品 来 报价 , 就 像 你 在 市 场 上 向 
陌生 人 卖 软件 一 样 。 如 果 你 给 几 个 客户 做 了 类 似 的 东西 (比如 一 个 询 
价 管理 工具 或 是 一 个 全 局 搜索 功能 )， 就 可 以 按照 固定 价格 给 以 后 的 
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客户 报价 。 当 你 把 客户 工作 产品 化 之 后 ,就 可 以 给 自 认 为 有 价值 的 东 
西 标 上 一 个 价格 ， 日 后 还 可 以 用 其 他 价值 指标 来 提 价 。 

同时 , 把 客户 工作 产品 化 还 能 让 我 们 保持 诚实 。 假 设 有 人 需要 我 
们 刚刚 给 男 一 个 客户 做 好 的 某 个 功能 , 理论 上 , 我 们 不 需要 再 像 第 一 
次 开发 那样 花 掉 二 十 个 小 时 ， 也 许 只 需要 几 个 小 时 来 复制 一 份 即 可 。 
要 是 把 时 间作 为 唯一 的 标准 , 我 们 第 二 次 收费 就 只 能 比 第 一 次 少 很 多 
To 但 这 毫 无 道理 , 因为 这 个 新 功能 对 于 第 二 个 客户 的 价值 和 对 第 一 
个 客户 是 一 样 的 。 

如 果 改 用 灵活 性 、 专 业 知识 和 速度 作为 指标 , 那么 第 二 次 收取 同 
样 的 钱 就 是 合理 的 了 。 我 们 甚至 还 可 以 改进 第 一 次 的 产品 , 这 样 就 可 
以 标 上 更 高 的 价格 。 

我 们 工作 的 价值 比 滴答 流逝 的 时 间 要 多 得 多 。 
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如 果 你 是 一 个 曾经 和 项 目 经 理 合作 过 的 程序 员 , 我 几乎 可 以 肯定 
地 说 ,你 有 过 因为 他 们 而 感到 郁闷 的 时 候 。 当 你 奋力 苦战 一 个 复杂 功 
能 的 时 候 ,， 项 目 经 理 翩然 来 临 ， 居 然 好 意思 问 你 什么 时 候 能 够 做 完 。 
当 你 花 了 无 数 时 间 来 条 分 缕 析 地 解决 代码 中 一 个 次 层次 的 关键 问题 
的 时 候 , 项 目 经 理 又 火 急 火 粽 地 来 了 , 催 着 你 修改 一 个 无 关 紧要 的 按 
钮 标签 。 哦 ， 现 在 项 目 经 理 又 来 了 , 问 你 是 不 是 能 够 今天 就 搞定 那个 
客户 毫 无 预兆 提出 来 的 新 功能 要 求 。 

你 知道 这 是 什么 感觉 。 在 内 心 深 处 ， 你 总 觉得 项 目 经 理 没 干 多 少 
事 ， 他 无 非 是 问 你 什么 时 候 、 怎 么 样 、 是 不 是 能 够 做 某 件 事 ， 而 你 才 
是 那个 在 细节 上 呕心沥血 、 真 正 付出 劳动 来 挣 工资 的 人 ， 对 吧 ? 

对 程序 员 来 说 , 要 是 在 工作 上 过 到 什么 难处 , 一 般 是 因为 软件 中 
有 需要 解决 的 困难 问题 。 我 们 会 全 心 投 入 几 个 小 时 ,历经 磨难 ; 我 们 
会 在 挫折 和 狂喜 的 情绪 中 跌宕 起 伏 。 对 于 我 们 程序 员 来 说 , 艰苦 的 工 
作 在 于 管理 产品 。 我 们 对 软件 了 如 指 掌 ， 正 如 在 第 40 篇 中 谈 到 的 一 
样 ， 软 件 是 我 们 唯一 应 该 专注 的 东西 。 


项 目 管理 主要 是 人 的 管理 


但 项 目 经 理 却 有 不 同 的 目标 。 好 的 开发 人 员 是 软件 领域 的 专家 ， 
而 好 的 项 目 经 理 是 客户 领域 的 专家 。 他 们 和 电话 或 邮件 那 头 的 人 形成 
了 亲密 的 工作 关系 。 他 们 知道 什么 时 候 可 以 推 延 , 或 者 什么 东西 对 于 
客户 来 说 是 真正 重要 的 一 一 即使 我 们 可 能 不 这 么 看 。 客户 工作 对 于 项 
目 经 理 来 说 可 能 是 一 场 情绪 上 的 挣扎 。 
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项 目 管 理 是 把 双 刃 剑 


在 餐馆 里 , KEARI. PARET RACKA, RZ 
怨 的 人 通常 是 服务 员 。 要 是 碰 上 特别 糟糕 的 晚餐 ,顾客 一 般 会 要 求 见 
餐厅 经 理 ， 抱 忽 “ 这 是 他 们 吃 过 的 最 差 的 一 顿 饭 "”。 厨 房 里 那些 大 后 
呢 ? 一 般 都 没 他 们 什么 事 。 

可 是 , 在 那些 特别 美妙 的 晚上 ,如 果 有 人 吃 了 他 们 一 生 中 最 好 的 
一 顿 饭 ， 他 会 感谢 谁 呢 ? 不 是 服务 员 ， 也 不 是 餐厅 经 理 ， 而 是 大 局 ! 
大 厨 们 甚至 还 时 不 时 能 出 来 露 个 脸 ， 接 受 客人 的 鞠躬 呢 。 

我 们 这 个 行业 也 是 这 么 回 事 。 从 客户 的 角度 来 说 , 项 目 经 理 代表 
的 就 是 你 们 公司 。 在 整个 设计 师 和 程序 员 的 团队 里 , 只 有 项 目 经 理 是 
需要 对 其 他 所 有 人 的 行为 负责 的 人 。 如 果 有 一 个 程序 员 莫 奖 业 业 , 但 
他 邻 桌 的 同事 却 有 失 水 准 , 项 目 经 理 就 无 可 避免 地 要 独自 承担 把 坏 消 
息 告 诉 客户 的 任务 ， 并 忍受 接 下 来 的 煎熬 。 

但 如 果 一 个 软件 能 够 按时 在 预算 内 漂亮 地 发 布 ， 享 受 赞扬 的 是 
程序 员 。 我 们 是 午餐 时 能 够 从 高 兴 的 客户 那里 得 到 免费 比 莹 和 啤酒 
的 人 。 

项 目 管理 的 重要 性 不 仅 限于 软件 本 里 , 而 且 这 个 工作 常常 还 吃力 
不 讨好 。 所 以 ,下 次 你 的 项 目 经 理 要 求 你 实现 客户 要 求 的 新 功能 时 ， 
不 要 马上 就 愤然 暴 起 ， 而 要 找 找 真 正 驱动 这 个 需求 的 原因 。 你 也 许 
可 以 推荐 一 个 更 为 简单 的 变通 方案 , 也 可 以 好 好 地 讲 出 道理 来 彻底 反 
RE o 

你 给 项 目 经 理 提供 的 面 对 客户 的 “弹药 ” 越 多 ， 他 们 就 越 能够 做 
好 自己 的 工作 。 

在 本 章 中 , 我 们 看 到 了 客户 管理 的 微妙 之 处 。 最 后 ,好 的 客户 管 
理 常 常 是 通过 我 们 自身 的 价值 实现 的 。 如 果 我 们 充满 热情 、 令 人 愉快 ， 
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客 


户 


那么 客户 也 能 间接 地 体会 到 我 们 这 一 行 的 妙 处 。 如 果 我 们 行事 坦荡 、 


ABSA AR, 可 能 产生 冲突 的 时 刻 也 会 变 成 一 个 重新 审视 软件 初始 目标 


的 机 会 。 


在 下 一 章 里 ,我们 还 是 回来 谈 谈 那些 不 是 与 人 打交道 的 东西 吧 。 
我 们 和 代码 之 间 也 有 同样 重要 的 一 段 关系 需要 维护 呢 。 
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到 现在 为 止 , 我 们 已 经 讨论 了 程序 员 生 活 中 的 方方面面 , 但 和 我 
们 挣 钱 的 家 伙 却 没有 什么 关系 。 本 章 我 们 会 回 到 主题 ， 回 到 根本 ， 回 
到 我 们 用 来 养家 糊口 的 这 件 事 上 。 

代码 是 我 们 所 用 的 最 基本 的 材料 , 但 我 们 看 待 代码 的 方式 和 其 他 
建造 者 看 待 他 们 的 原材料 的 方式 是 不 一 样 的 。 

和 其 他 建造 行业 不 同 , 我 们 的 材料 是 取 之 不 尽 的 。 如 今 我 们 还 可 
以 把 它们 分 发 给 任何 人 , 分 发 到 任何 地 方 , 距离 对 我 们 来 说 完全 不 是 
问题 。 我 们 可 以 随心 所 欲 地 复制 建造 的 东西 ; 我 们 可 以 在 已 有 代码 的 
基础 上 快速 开发 ,也 可 以 对 代码 层 进行 扩展 , 添 枝 加 叶 ; 我 们 不 需要 
等 待 材料 干 透 或 是 定型 。 现 实 的 物理 世界 中 没有 什么 东西 是 这 样 的 。 
正 因为 这 些 原 因 ， 人 们 很 容易 不 把 代码 太 当 回 事 。 

本 章 讲 的 是 我 们 和 代码 相处 的 方式 , 这 是 向 我 们 每 天 所 使 用 的 原 
材料 致敬 。 我 相信 ， 最 好 的 程序 员 真 的 和 代码 有 一 段 情 缘 。 他们 只 
在 确实 必要 的 时 候 才 会 使 用 代码 , 只 有 在 正确 的 时 候 才 会 从 别处 借用 
代码 ， 其 至 会 在 面 对 合 适 的 挑战 时 用 代码 创建 他 们 自己 的 框架 。 
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Z4 篇 ”与 代码 是 不 得 已 而 为 之 


当 纽 约 一 座 办 公 楼 的 人 们 开始 抱怨 电梯 服务 越 来 越 差 时 , 大 楼 的 
管理 方 找 了 一 家 咨询 公司 来 看 看 哪里 出 了 问题 。 咨询 公司 得 出 的 结论 
是 等 竺 电梯 的 时 间 太 长 。 要 解决 租户 的 抱怨 ,就 意味 着 可 能 要 增加 电 
梯 , 并 实施 新 的 电脑 控制 来 提高 电梯 的 效率 。 这 种 改动 的 花 销 实在 太 
大 了 。 

大 楼 人 事 部 雇用 的 一 个 年 轻 的 心理 学 家 走 了 进来 。 他 的 建议 
是 在 电梯 厅 里 放 上 镜子 。 等 待 电梯 的 时 间 长 并 不 是 问题 ， 无 聊 才 
是 问题 。 

他 的 建议 奏效 了 。 人 们 有 事 做 了 一 一 照 镜子 ， 便 不 再 抱怨 等 电梯 
的 时 间 太 长 了 。 同 样 的 问题 ， 解 决 方式 可 以 大 不 一 样 。 

我 们 之 中 最 有 热情 的 人 , 是 那些 把 大 部 分 工作 时 间 花 在 批判 性 和 
创造 性 思维 上 的 人 ， 他 们 常常 是 为 了 找到 更 简单 、 更 “ 懒 ”的 解决 方 
案 。 答 案 并 不 总 是 埋头 去 写 更 多 的 代码 这 种 明显 而 覃 力 的 方式 。 

有 时 候 最 好 的 答案 是 在 别处 发 现 的 。 下 次 遇 到 纽约 办 公 楼 的 电梯 
问题 时 ， 问 问 自 己 下 面 这 些 问题 : 

口 有 人 以 前 做 过 这 件 事 吗 ? 我 能 不 能 拿 现成 的 代码 , 这 样 就 不 用 
我 自己 去 干 这 种 脏 活 累 活 了 ? 

O 这 个 功能 对 于 软件 的 目标 真 的 重要 吗 ? 这 个 功能 是 不 是 已 经 
有 了 ， 只 是 需要 不 同 的 用 户 体验 来 实现 ? 

口 有 没有 比 我 现在 使 用 的 更 简单 的 编程 方式 ? 即使 它 没有 完全 
解决 问题 ， 是 不 是 也 值得 做 出 让 步 ? 

口 我 能 让 这 个 工作 自动 化 吗 ? 我 能 不 能 编 个 软件 来 写 这 个 算法 ， 
这 样 我 以 后 就 不 用 重复 劳动 了 ? 
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如 果 面 对 每 个 任务 都 直接 进入 “ 写 代码 ”模式 的 话 , 我 们 就 失去 
了 一 个 认真 思考 为 什么 要 写 它 的 机 会 。 反 过 来 ,如 果 我 们 能 够 批判 性 
地 思考 为 什么 要 写 代码 , 就 可 以 把 大 部 分 的 编程 时 间 花 在 真正 重要 的 
事情 上 。 
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关于 我 们 用 的 这 个 材料 有 一 个 绝妙 的 讽刺 。 虽然 写真 正 伟 大 的 代 
码 很 困难 , 但 一 旦 我 们 写 好 了 这 段 精致 的 代码 , 就 可 以 很 容易 地 把 它 
发 往 全 世界 ,一 点 都 不 会 失真 或 者 变质 。 伟 大 的 代码 即使 有 很 多 程序 
员 用 过 ， 也 不 会 丧失 其 内 在 价值 。 事 实 上 ， 人 恰恰 相反 。 

作为 一 个 社区 , 程序 员 一 直 都 在 帮助 其 他 程序 员 。 我 们 可 以 把 同 
事 做 好 的 东西 直接 拿 过 来 ， 以 加 快 我 们 的 很 多 流程 。 
开发 软件 就 像 逛 超市 

比如 ,我们 可 以 用 Sass 来 写 更 好 维护 的 样式 表 , 然 后 再 转 成 CSS。 
我 们 手头 有 jQuery 和 CoffeeScript 两 件 利器 。 这 两 个 优雅 的 框架 以 
JavaScript 为 基础 ， 却 隐藏 了 它 所 有 了 哆 哄 的 语法 细节 。 需 要 一 个 
JavaScript 插件 来 用 灯箱 效果 显示 图 片 ? 至 少 有 三 十 个 这 样 的 插件 ， 
而 且 都 是 专门 为 jQuery 写 的 ! O 

很 多 年 轻 一 代 的 程序 员 从 来 都 不 用 写 底 层 SQL 数据 库 查 询 ， 
为 对 象 关系 映射 4ORM ) 工具 和 代码 生成 框架 已 经 帮 我 们 完成 了 将 
关系 数据 库 中 的 数据 转换 成 对 象 的 烦琐 工作 。 需 要 ORM TH? AJL 
百 个 开源 和 专 有 产品 在 等 着 你 呢 。” 

在 Web 应 用 的 层面 ，Rails 和 Django 等 开发 框架 让 我 们 可 以 开发 
数据 库 驱 动 的 Web 应 用 ， 同 时 省 掉 了 用 户 界面 和 数据 库 中 间 的 大 部 


中 有 关 三 十 个 灯箱 实现 ， 请 参见 http:/Avww.designyourway.net/blog/resources/30- 
efficient-jquery-lightbox-plugins/。 
@ 有 关 多 种 语言 的 ORM 列表 ， 请 参见 http://en.wikipedia.org/wiki/List_of_object- 


relational_mapping software. 
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分 手工 劳动 。 我 们 现在 可 以 在 它们 的 悉心 呵护 下 享受 工作 了 。 

任何 工作 , 无 论 大 小 , 无 论 是 在 哪个 开发 展 次 ,我 们 几乎 都 可 以 
找到 别人 写 好 的 优美 工具 来 满足 我 们 的 需要 。 大 多 数 情况 下 , 完全 有 
理由 去 用 这 些 工具 。 即 使 它们 没有 完美 地 提供 我 们 想 要 的 功能 , 即使 
我 们 需要 稍微 委屈 一 下 自己 的 “口味 ”来 适应 它们 , 但 和 自己 写 一 遍 
相 比 ， 这 能 省 下 不 少时 间 ， 所 以 通常 都 是 值得 的 。 

比如 ， 我 从 来 不 会 考虑 自己 开发 持续 集成 系统 。Jenkins ( 原 
Hudson ) 已 经 完美 地 做 好 了 。 我 绝 不 会 自己 写 数据 库 同步 工具 。 我 会 
高 高 兴 兴 地 花 上 几 百 美元 ， 买 上 一 个 类 似 Red Gate 的 工具 ， 它 会 代 
我 把 合并 数据 库 模 式 中 可 能 出 现 的 所 有 边缘 情况 都 搞定 。 对 于 大 多 
数 开发 工作 来 说 , 我 会 用 那些 在 这 个 领域 比 我 牛 得 多 的 人 写 的 代码 来 
搞定 。 

从 这 个 意义 上 说 ,如今 开发 应 用 的 感觉 就 有 点 像 逛 超市 ; 也 许 开 
源 运 动 更 像 是 慈善 超市 "。 我 们 可 以 把 所 有 这 些 好 工具 都 堆 进 我 们 的 
购物 车 ,然后 结账 走 人 。 到 家 之 后 ,我 们 把 这 些 好 代码 逐个 拆 开 , 自 
己 花 点 儿 心 思 把 它们 “ 缝 ” 在 一 起 , 一 个 应 用 就 诞生 了 。 如 今 让 软件 
跑 起 来 真 的 非常 快 。 
“快速 编码 ”文化 的 副作用 

谢 天 谢 地 , 使 用 这 些 工具 不 会 像 其 他 行业 使 用 “高 效 框架 ”一 样 
在 公众 中 造成 副作用 。 只 要 我 们 的 软件 能 设计 出 来 , 运行 得 也 还 不 错 ， 
用 户 是 不 会 注意 我 们 在 下 面 使 用 什么 材料 的 。 可 不 是 每 个 行业 都 有 这 


么 好 的 运气 。 


@ Ae (Goodwill Store) 起 源 于 美国 ， 主 要 业务 是 接收 、 处 理 、 销 售 市 民 们 捐 
赠 的 旧 物 ， 并 将 销售 收入 作为 善 款 。 一 一 译 者 注 
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比方 说 食品 行业 吧 。20 世纪 五 六 十 年 代 的 时 候 ， 人 快餐 最 时 艇 了 。 
它 是 未 来 主义 , 是 进步 的 象征 。 它 特别 能 够 适应 活 在 车 轮 上 的 生活 方 
式 ， 让 人 们 “ 边 走 边 吃 "， 迅 速 享受 还 不 错 的 食品 。 


se 


ANDERSON 


“不 错 ! 就 和 我 妈妈 过 去 常 点 的 一 样 !” 


但 是 几 十 年 之 后 , 那些 神秘 奇妙 的 食品 开始 失宠 了 。 这些 食 品 的 
半自动 化 制作 让 肥胖 症 在 我 们 的 社会 里 流行 开 来 。 RAE, HW 
物 饲养 条 件 、 使 用 激素 和 杀 虫 剂 是 低 价 大 规模 食品 生产 的 前 提 。 由 此 
种 种 ， 我 们 又 回 过 头 爱 上 了 手工 制作 的 真正 食品 。 

幸运 的 是 ， 我 们 的 “快速 代码 ”没有 这 种 问题 。 换 句 话说， 复辟 
到 “从 头 一 行 一 行 写 代码 ”似乎 不 太 可 能 。 高 度 依赖 预制 好 的 库 和 框 
架 ， 快 速 让 软件 跑 起 来 这 种 做 法 还 是 会 治 用 下 来 的 。 
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但 确实 还 是 有 些 隐忧 。 在 这 些 框架 中 , 很 多 关键 的 谋划 都 被 刻意 
地 抽 掉 了 。 留 下 来 的 是 快速 的 高 层次 方法 , 可 以 解决 用 其 他 手段 解决 


就 会 很 复杂 的 问题 。 但 原作 者 的 那些 灵感 , 现在 都 深 深 地 埋 在 了 编程 
接口 下 面 的 某 个 地 方 。 


如 今 , 有 了 海量 的 高 效 平 台 , 我 们 可 能 很 快 就 会 丧失 对 于 底层 如 
何 工作 的 欣赏 、 兴 趣 和 理解 。 
这 样 就 危险 了 。 
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第 47 篇 ”代码 是 最 好 的 初级 程序 员 


代码 使 用 起 来 如 此 之 方便 ， 所 以 我 们 很 容易 就 忘 了 代码 有 和 多么 
伟大 。 

现在 ， 让 我 们 暂时 忘掉 最 新 的 jQuery 插件 或 是 Rails 的 补丁 吧 。 
想 想 伟大 的 数学 家 卡尔 . 弗 雷 德里 克 * 高 斯 ， 要 是 他 在 18 世纪 就 有 
编程 语言 可 用 的 话 会 是 什么 样子 。 


高 斯 可 以 用 代码 做 的 事情 


关于 高 斯 有 一 个 很 著名 的 故事 。 高 斯 还 在 上 小 学 的 时 候 , 有 一 天 ， 
他 的 那 位 懒得 出 了 名 的 老师 让 整个 班 的 学 生计 算 从 1 加 到 100 得 多 
少 ,希望 这 个 题 可 以 占 掉 学 生 们 很 多 时 间 。 可 让 这 位 老师 头疼 的 是 ， 
年 轻 的 高 斯 只 用 了 几 分 钟 就 把 正确 答案 告诉 了 老师 : 5050。 

他 是 怎么 算得 这 么 快 的 呢 ? 如 果 高 斯 当时 有 编程 工具 的 话 , 他 可 
能 就 写 了 这 么 一 段 代码 来 得 到 答案 : 


public int sum range of positive integers to 100() 


{ 


int sum; 


for (int i = 1; i <= 100; i++) 


{ 

sum += i; 
} 
return sum; 


} 
他 可 能 很 快 地 想 了 想 , 然后 把 程序 重 写 为 更 为 普遍 的 形式 ,以 便 
应 对 老师 可 能 让 他 算 其 他 数字 范围 的 情况 ， 即 : 
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public int sum range of integers(int first, int last) 
{ 

if (last < first) 

{ 


throw new Exception("Last must be larger than first!"); 
} 


int sum; 


for (int i = first; i <= last; i++) 


{ 

sum += i; 
} 
return sum; 


} 

当然 , 年 轻 的 高 斯 当时 没有 这 种 选择 。 那 他 是 如 何 这 么 快 得 出 答 
案 的 呢 ? 

他 没有 把 数字 一 个 个 加 起 来 ， 而 是 用 了 一 种 很 聪明 的 办 法 。 他 不 
是 把 数字 挨个 加 起 来 的 , 而 是 将 数列 的 首尾 两 数 相 加 , 先是 1 和 100, 
然后 是 2 和 99，3 和 98， 以 此 类 推 。 

(1 + 100) + (2 + 99) + +++ + (49 + 52) + (50 + 51) 

这 样 就 出 现 了 一 个 简单 的 模式 。 他 发 现 这 里 有 50 对 数字 ， 每 对 
数字 的 和 都 是 一 个 奇妙 的 数字 一 一 101。 

101 + 101 + 101 + :+101+101+101 

于 是 将 100 个 数 相 加 的 问题 就 简化 成 了 一 个 简单 的 乘法 运算 : 

50 x 101 = 5050 

高 斯 的 方法 只 有 人 才能 想 得 出 来 。 他 给 一 个 乍 看 起 来 无 比 繁琐 的 
问题 找到 了 一 种 优雅 的 解法 。 他 的 探索 比 他 大 部 分 同学 采用 的 繁琐 的 
依次 求 和 要 好 得 多 。 最 后 ， 他 得 出 了 一 个 漂亮 的 小 公式 
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从 1 到 nn 的 所 有 整数 的 和 =n x (n+1)/2 

那 我 们 的 代码 是 如 何 处 理 这 个 问题 的 呢 ? 前 面 提 到 的 代码 也 可 
以 得 到 相同 的 结果 ,不 过 做 法 却 很 “暴力 ” 和 我 们 告诉 它 的 做 法 
一 样 。 鉴 于 今天 的 处 理 需 如 此 之 快 , 那么 即使 这 个 方法 效率 很 差 ， 运 
行 我 们 代码 的 软件 也 肯定 比 高 斯 算得 快 得 多 。 

不 过 ， 到 了 某 个 规模 ， 高 斯 的 方法 就 会 胜出 了 。 如 果 要 高 斯 算 1 
到 4 000 000 AYA, AB sum range of integers() 算得 就 慢 了 。 

这 就 意味 着 ， 到 了 某 个 数值 ， 高 斯 很 可 能 能 够 打败 代码 ， 因 为 虽 
然 这 位 天 才 知 道 用 一 个 简单 的 公式 就 可 以 计算 结果 , 可 我 们 可 怜 的 程 
序 还 是 要 这 样 做 : 


1+2+3 +- + 3 999 998 + 3 999 999 + 4 000 000 


代码 的 迷人 特质 


高 斯 的 故事 可 以 给 我 们 一 些 启 迪 : 代码 和 人 解决 问题 的 方式 有 何 
不 同 ,代码 擅长 处 理 繁琐 的 东西 一 一 基于 算法 和 规则 来 解决 问题 一 一 
比 人 要 强 得 多 。 它 不 仅 是 擅长 , 简直 具有 一 个 无 可 匹敌 的 、 高 效 又 廉 
价 的 初级 程序 员 的 所 有 特质 。 

代码 不 会 偷懒 

代码 永远 不 会 擅自 决定 抄 个 捷径 或 是 偷工减料 。 本 篇 开头 那 小 段 
代码 会 把 4 000 000 个 整数 挨个 加 起 来 ， 绝 不 会 跳 过 一 个 。 代 码 执行 
的 精确 度 是 无 可 挑剔 的 。 

代码 不 会 嫌 烦 

想象 一 下 写 这 样 一 个 小 程序 : 


int x = 0; 


while (x != x + 1) 
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{ 
// 什么 也 不 做 
} 


虽然 这 个 任务 看 起 来 很 不 理智 , BARES N Ao 
无 用 功 , 除非 运行 时 引擎 能 够 察觉 这 个 无 限 循环 , 从 而 强制 中 止 程序 。 
代码 不 会 去 分 析 一 个 任务 是 否 重要 ， 也 不 会 在 意 自己 是 不 是 劳累 过 
度 ， 它 只 管 任劳任怨 地 执行 我 们 给 它 的 指令 。 

代码 不 会 遗忘 


在 本 篇 开头 ， 我 们 是 这 么 告诉 引擎 的 : 


“无 论 何 时 我 让 你 运行 sum_range_of_integers(1，100) ， 
建立 一 个 叫做 sum 的 整数 。 从 数字 1 开始 ,把 这 个 数值 加 到 sum 
上 ， 然 后 让 这 个 数值 增加 1。 一 直 做 下 去 ， 直 到 数字 达到 100。 
然后 给 我 此 时 sum 的 值 。” 


多 年 之 后 ,我 又 翻 出 这 段 程序 ， 重 新 调用 这 个 方法 ， 还 是 会 得 到 
一 样 的 结果 。 代码 永 远 不 会 忘记 要 它 做 的 事情 。 那 些 用 成 千 上 万 行 代 
码 搭建 起 来 的 软件 系统 也 是 如 此 。 无 论 规模 如 何 , 在 几 天 、 几 周 乃 至 
几 年 之 后 ， 代 码 还 是 会 记得 要 做 什么 。 人 类 做 得 到 吗 ? 

代码 很 廉价 

让 一 个 同事 坐 到 桌 前 去 把 1 到 4 000 000 的 数字 加 起 来 ， 如 果 他 
要 报酬 的 话 , 我 们 也 会 理解 的 。 也 许 我 们 可 以 按照 加 法 次 数 来 计算 佣 
金 ， 或 是 按 小 时 付费 。 回 头 看 看 第 8 篇 “工作 即 福利 ”， 对 于 这 种 高 
度 琐碎 的 工作 ， 福 利 是 可 以 带 来 动力 的 。 

幸运 的 是 ,我 们 从 来 不 需要 告诉 代码 有 关 金 钱 、 市 场 经 济 或 是 度 
假 别 墅 之 类 的 事情 。 代 码 从 不 求 回报 。 一 旦 教 给 代码 做 什么 事情 , 我 
们 就 可 以 拼命 压榨 它 了 。 不 会 有 什么 代码 劳动 法 之 类 的 麻烦 事 。 


图 灵 社 区 会 员 cindy282694 专 享 尊重 版 权 


134 #82 R B 

代码 很 快 

代码 执行 的 速度 和 我 们 做 事 的 速度 真是 不 可 同日 而 语 。 它 的 速度 
是 由 硬件 所 限制 的 ， 随 着 时 间 推 移 ， 这 个 限制 会 直下 小 人 类 对 这 
种 速度 实在 是 望尘莫及 。 

这 些 都 意味 着 什么 呢 ? 想象 一 下 有 个 求职 网 站 上 贴 了 这 么 一 则 
广告 : 


勤 备 的 程序 员 求 职 ! ! ! 


教 我 做 任何 事 ， 我 都 能 很 快 学 会 ， 并 且 会 马上 告诉 你 我 
是 不 是 需要 额外 的 信息 。 我 可 以 随时 工作 ,工作 量 不 限 。 我 
永远 不 会 忘记 你 说 的 话 ， 也 不 会 抱怨 工作 毫 无 挑战 。 我 特别 
擅长 繁琐 的 工作 。 

口 地 点 : 任何 地 方 
口 请 勿 向 本 人 推销 服务 或 商业 利益 
口 报酬 : 0 元 


毫 无 疑问 ,代码 是 有 史 以 来 最 伟大 的 初级 程序 员 。 它 特别 擅长 繁 
重 但 能 够 明确 定义 的 工作 。 它 从 不 抱 急 ， 除 非 我 们 的 指令 没有 意义 。 
它 廉 价 、 快 速 、 勤 勉 、 稳 定 ， 还 不 夹杂 个 人 情感 。 很 多 公司 会 在 一 秒 
钟 之 内 就 雇用 十 名 具有 这 些 特 质 的 程序 员 。 

代码 的 威力 真是 可 观 。 
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第 48 篇 ”把 机 器 和 人 的 工作 区 分 开 


如 果 代 码 是 初级 程序 员 的 理想 “候选 "， 我 们 就 应 该 让 它 马 上 开 
工 。 我 们 越 早 摆脱 繁重 的 算法 性 工作 ( 最 适合 代码 做 的 工作 ) 就 能 越 
早 专心 去 做 更 有 意思 的 事情 。 

我 们 编程 时 都 有 过 这 种 经 历 : 把 一 个 项 目的 代码 贴 到 另 一 个 项 目 
里 , 或 是 浪费 几 个 小 时 去 写 我 们 明知 以 前 写 过 的 功能 。 有 时 候 我 们 没 
有 灵感 去 重新 思考 整个 流程 ,结果 就 这 人 么 耗 过 一 天 , 然后 再 做 下 面 的 
工作 。 


“最 近 我 这 儿 看 起 来 全 都 是 零 啊 。 


这 种 被 动 的 心态 必须 要 改 改 了 。 我 们 没 必要 反复 写 哪 怕 很 小 的 脚 
本 , 完全 可 以 写 一 个 程序 来 帮 我 们 做 这 个 工作 。 程序 员 的 时 间 太 宝贵 
T, 不 能 浪费 在 重复 性 的 劳动 上 。2006 年 , 我 和 伙伴 一 起 创建 We Are 
Mammoth 的 时 候 ， 我 一 直 想 的 就 是 这 个 。 

起 初 ， 我 们 用 C# 在 一 个 .NET 后 端 上 制作 Flash 应 用 。 干 了 几 个 
月 之 后 ,我 发 现 有 些 工作 是 重复 性 的 , 即 我 们 每 次 都 机 械 重 复 的 工作 。 
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看 到 同样 的 流程 迭代 几 次 之 后 ， 我 开始 把 繁重 却 可 以 用 算法 描述 的 
部 分 与 每 个 项 目 中 的 定制 部 分 区 分 开 来 。 这 种 区 分 就 像 油 和 水 一 样 
分 明 。 

我 们 做 的 每 个 应 用 都 遵循 一 个 公共 的 套路 。 设 计 好 数据 库 之 后 ， 
我 们 会 用 SQL 写 上 一 些 存 储 过 程 ， 然 后 在 C# 里 面 创建 对 象 ， 从 这 些 
存储 过 程 中 抽取 数据 ， 变 成 自己 的 属性 。 然 后 再 写 上 一 些 Web 钩子 ， 
和 用 ActionScript 写成 的 另 一 套 类 进行 交互 。 只 有 到 了 这 里 ， 我 们 才 
开始 在 Flash 端 进行 功能 开发 。 这 一 大 堆 工 作 真是 累 人 又 无 聊 ， 让 机 
器 人 来 做 比 让 人 做 强 多 了 。 


软件 中 有 两 个 部 件 是 没 办 法 用 算法 生成 的 。 首 先是 数据 库 模 式 。 
我 们 给 汽车 公司 、 家 具 厂 、 经 纪 公司 、 软 件 分 销 商 和 快餐 连锁 店 做 过 
软件 。 他 们 的 数据 库 都 是 量 身 定做 来 解决 独特 的 商业 问题 的 。 其 次 ， 
用 户 界 面 可 不 是 无 关 紧 要 的 ,得 为 每 个 客户 量 身 定制 。 这 些 才 是 我 们 
想 要 投入 大 部 分 时 间 的 工作 。 

这 时 我 们 就 停 下 来 ， 花 些 时 间 来 制作 我 们 自己 的 代码 生成 器 。 

为 了 更 好 地 描述 如 何 从 流程 中 把 可 重复 的 部 分 提取 出 来 , 想象 一 
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下 从 头 措 建 一 个 博客 的 情景 。 我 们 从 最 底层 的 数据 库 开 始 。 数 据 模型 
可 能 包含 这 样 的 三 张 表 : 


DQ Posts(ID, Title, CreateDate, Body, AuthorID) 
ū Authors(ID, FirstName, LastName) 
D Comments(ID, Comment, Email, CreateDate, PostID) 


如 果 你 熟悉 对 象 关系 数据 库 建 模 ， 这 个 模型 还 是 很 显而易见 的 。 
文章 ( Posts ) 都 有 标题 、 正 文 、 创 建 日 期 ， 并 通过 外 键 AuthorID 
来 和 一 个 作者 ( Author ) 建 立 关 系 ,AuthorID 通过 匹配 作者 ( Author ) 
表 中 的 ID 列 来 指向 该 表 中 的 一 条 记录 。 评论 (Comments ) 表 则 包含 
评论 、 电 子 邮 件 地 址 、 创 建 日 期 并 通过 外 键 PostID 来 关联 原文 
Post。PostID 匹配 文章 (Posts ) 表 中 的 ID 列 。 


找 出 可 重复 的 编码 任务 


开张 初期 , 我 们 开始 写 软件 的 时 候 , 会 为 数据 模型 中 的 每 一 张 表 
写 用 来 插入 /创建 ( insert/create )、 读 取 (read), Ht (update ) 和 删 
BR (delete) 表 中 记录 的 存储 过 程 。 这 种 “CRUD” 方 法 就 是 在 数据 库 
中 操作 记录 的 基本 过 程 。 下 面 就 是 给 Posts 表 写 插入 过 程 时 要 敲 的 


代码 : 


CREATE PROCEDURE CreatePost ( 


@Ti 


tle NVARCHAR(255), 


@Body NTEXT, 
@CreateDate DATETIME, 


@Au 
AS 


thorID INT) 


INSERT INTO Post VALUES ( 


@Ti 


tle, 


@Body, 
@CreateDate, 


@Au 


thorID) 
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在 CreatePost 这 个 过 程 中 ,我 们 就 简单 地 列 出 Posts 表 中 除 主 
E (这 里 是 ID 字段 ) 之 外 的 所 有 字段 ， 然 后 用 SQL 写 一 个 INSERT 
语句 ， 加 上 对 应 的 输入 参数 。 

由 于 通过 观察 数据 模型 就 可 以 精确 描述 如 何 写 此 类 方法 , 用 程序 
就 可 以 生成 任何 一 般 性 的 创建 方法 了 。 前 面 所 说 的 过 程 也 可 以 在 
Authors 和 Comments 表 上 重复 进行 。 

我 们 可 以 把 同样 的 套路 用 在 一 般 性 的 UPDATE、READ 和 DELETE 
过 程 上 。 比 如 ， 要 写 一 个 更 新 过 程 ， 我 们 就 列 出 表 中 所 有 字段 ， 用 
BOE O a T 
句 中 的 条 件 。 用 这 种 方法 写 出 来 的 UpdatePost 过 程 就 会 是 这 样 的 : 


CREATE PROCEDURE UpdatePost ( 
@ID INT, 
@Title NVARCHAR(255) , 
@Body NTEXT, 
@CreateDate DATETIME, 
@AuthorID INT) 


AS 

UPDATE Post 

SET 
Title = @Title, 
Body = @Body, 


CreateDate = @CreateDate, 

AuthorID = @AuthorID 
WHERE 

ID = @ID 


我 们 还 能 生成 什么 样 的 查询 语句 呢 ? 举 个 例子 , 我 们 可 以 基于 这 
些 表 之 间 的 关系 ,将 其 推广 到 选择 查询 上 。 比 如 ,文章 都 有 作者 ， 那 
我 们 就 可 以 写 一 个 SELECT 存储 过 程 ， 来 查询 某 个 作者 ID 对 应 的 所 
有 博客 文章 。 我 们 就 把 它 叫做 GetALLPostsByAuthorsID 吧 。 我们 
也 可 以 写 出 类 似 的 过 程 ， 来 查询 某 个 文章 ID 下 的 所 有 评论 
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(GetALLCommentsByPostID). 


CREATE PROCEDURE GetAllPostsByAuthorID(@ID INT) 
AS 
SELECT * FROM Posts WHERE AuthorID = @ID 


CREATE PROCEDURE GetAllCommentsByPostID(@ID INT) 
AS 
SELECT * FROM Comments WHERE PostID = @ID 


我 们 的 存储 过 程 中 又 出 现 了 另外 一 种 公式 化 的 模式 。 对 于 表 [X] 
中 的 任何 外 键 [Y] ， 我 们 都 可 以 写 出 一 个 这 种 形式 的 存储 过 程 : 
GetALL[X]By[Y]ID。 

让 我 们 再 进一步 。 我 们 可 能 想 要 按照 某 个 字段 来 筛选 记录 。 比如 ， 
我 们 希望 获得 某 一 天 的 文章 : 

GetAllPostsWhereCreateDateEquals(CreateDateParam) 

或 按照 姓氏 查询 作者 : 

GetAllAuthorsWhereLastNameEquals (LastNameParam) 

又 出 现 了 一 个 公式 。 对 于 表 [X] 中 任何 可 以 进行 筛选 的 字段 [Z] ， 
给 定 一 个 参数 [P] ， 我 们 就 可 以 写 出 一 个 存储 过 程 : GetALL[X] 
Where[Z]Equals([P]). 

在 建立 C# 数 据 访 问 层 、Flash 层 能 够 调用 的 API 以 及 ActionScript 
层 本 身 的 时 候 , 也 可 以 找到 类 似 繁琐 但 又 可 以 用 算法 描述 的 过 程 。 所 
有 这 些 底层 的 脏 活 累 活 都 特别 适合 我 们 上 一 篇 文章 中 的 虚构 求职 者 。 
或 者 ， 更 现实 地 说 ， 我 们 可 以 写 出 聪明 的 程序 来 帮 我 们 干 活 。 

我 们 每 次 开始 新 项 目的 时 候 , 这 些 工作 都 不 算 少 , 但 是 只 要 找 出 
这 类 工作 的 公式 ， 我 们 就 可 以 把 这 种 工作 交 给 …… 机 器 人 去 做 。 
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代码 生成 是 每 个 程序 员 都 应 当 经 历 的 旅程 。 这 可 以 解放 思想 的 束 
缚 ,让 我 们 把 代码 看 做 转变 工作 方式 的 有 力 工 具 ， 而 不 仅仅 是 用 来 写 
程序 的 材料 。 

那么 ， 我 们 如 何 着 手 去 写 一 个 代码 生成 器 呢 ? 要 想 真 正 了 解 的 
话 ， 我 强烈 推荐 Jack Herrington 的 杰作 Code Generation in Action 
[Her03]。 该 书 详 述 了 生成 各 类 代码 的 技巧 和 高 层次 模式 。 但 我 们 开始 
的 时 候 并 不 需要 如 此 精妙 的 细节 。 下 面 就 是 一 些 基 本 的 东西 。 


定义 输入 源 


首先 要 创建 一 个 输入 源 。 我们 的 代码 生成 器 所 需要 的 所 有 参数 都 
汇集 到 这 里 。 输 入 源 可 以 很 简单 〈 比 如 普通 的 XML 或 JSON 文 件 )， 
也 可 以 很 健壮 〈 比如 数据 库 本 身 )。 

我 们 公司 部 署 的 第 一 个 代码 生成 器 X20 是 用 XML 文件 作为 输入 
源 的 。XML 文件 定义 了 我 们 要 生成 代码 的 数据 库 中 的 表 、 字 段 和 外 
键 。 下 面 就 是 一 个 将 第 48 篇 中 的 博客 数据 模型 转换 成 XML 输入 源 的 
例子 。 


<input_source> 


<table name="Posts"> 
<field name="ID" type="int" identity="true" /> 
<field name="Title" type="NVarChar" Length="100"/> 
<field name="CreateDate" type="DateTime" /> 
<field name="Body" type="NText" /> 
<foreignkey name="AuthorID" to_table="Authors" /> 
</table> 
<table name="Authors'"> 
<field name="ID" type="int" identity="true" /> 
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<field name="FirstName" type="NVarChar" length="50"/> 
<field name="LastName" type="NVarChar" Length="50" /> 
</table> 
<table name="Comments"> 
<field name="ID" type="int" identity="true" /> 
<field name="Comment" type="NText" /> 
<field name="Email" type="NVarChar" length="100" /> 
<field name="CreateDate" type="DateTime" /> 
<foreignkey name="PostID" to_table="Posts" /> 
</table> 


</input_source> 

随 着 时 间 的 推移 ， 你 的 输入 源 也 会 随 之 增长 。 你 会 发 现 越 来 越 多 
的 东西 要 生成 ， 也 就 需要 更 多 类 型 的 输入 。 比 如 ,在 X20 的 第 一 个 
版 本 开发 完成 几 个 月 后 ， 我 们 想 要 给 代码 生成 器 加 上 创建 文档 的 功 
能 。 我 们 给 每 个 table 和 field 节点 都 加 上 了 一 个 叫做 friendly_ 
description 的 属性 ,这 样 就 可 以 参考 这 些 属 性 来 为 ActionScript ft 
码 生 成 API 人 参考 文档 了 。 
选择 合适 的 编程 语言 

应 该 选择 适合 做 代码 生成 的 语言 来 编程 。 用 来 写 代 码 生成 器 的 语 
言 并 不 一 定 就 是 生成 代码 的 语言 。 在 X20 里 ， 我 们 用 CHES (SE 
成 器 ， 但 是 输出 则 有 SQL, C, HTML 和 ActionScript. 

所 选 的 语言 必须 具有 输入 输出 功能 , 这 样 你 才能 把 生成 的 代码 保 
存在 机 器 上 。 幸 运 的 是 ， 如 今 几 乎 所 有 的 主流 编程 语言 (C、C++、 
C#、VB Java, PHP, Python, Ruby, Perl) 都 支持 这 个 。 如 果 你 从 
来 没 写 过 读 写 文件 的 程序 , 就 花 上 一 个 小 时 来 研究 一 下 吧 。 这 个 工作 
你 的 代码 生成 器 要 做 上 很 多 。 

Herrington 优选 的 语言 是 Ruby, 因为 它 对 输入 输出 和 文本 模板 工 
具 (如 ERb 和 ERuby ) 的 支持 很 好 ， 对 于 他 举例 的 输入 源 语 言 一 一 
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XML 的 操作 也 很 方便 。 


在 输入 源 中 提取 有 用 信息 


有 了 输入 源 ， 写 一 个 程序 来 从 中 提取 有 用 的 信息 吧 。 在 上 例 中 ， 
我 们 把 XML 文件 的 内 容 映 射 成 其 C# 中 的 对 象 。 这 样 , 你 既 有 了 方便 
构建 输入 源 的 系统 (XML )， 又 有 了 根据 输入 源 生成 代码 后 方便 操作 
的 系统 ( 比如 C# 中 的 对 象 )。 

在 今天 的 体系 中 ，E4X (ECMAScript for XML ) 等 语言 已 经 让 将 
输入 源 转化 成 可 编程 对 象 的 工作 变 得 非常 顺畅 了 。 无 论 你 用 什么 方 
法 , 能够 方便 地 浏览 和 审查 输入 源 是 非常 重要 的 。 你 在 下 一 步 中 就 知 
道 为 什么 了 。 


给 你 的 输入 源 提供 者 配 上 模板 


有 了 可 以 用 的 编程 环境 和 输入 源 ,， 下 一 步 就 是 要 写 模 板 。 在 我 们 
的 博客 例子 中 , 开发 过 程 中 每 个 繁琐 的 部 分 都 有 一 个 公式 。 比 如 , 为 
了 生成 所 有 的 CRUD 语句 ， 我 们 无 非 是 遍历 数据 模型 中 的 每 张 表 ， 
然后 对 每 个 表 应 用 相同 的 语句 。 以 SQL 的 CREATE 语句 为 例 , 我 们 可 
以 先 拿 来 下 面 的 真实 SQL 代码: 

CREATE PROCEDURE CreatePost ( 

@Title NVARCHAR(255) , 

@CreateDate DATETIME, 


@Body NTEXT, 
@AuthorID INT) 


AS 
INSERT INTO Post VALUES ( 
@Title, 
@CreateDate, 
@Body, 
@AuthorID) 
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然后 把 定制 部 分 换 成 可 以 替换 的 变量 


CREATE PROCEDURE Create[cur table] ( 
[List of attributes as input _params]) 

AS 

INSERT INTO [cur table] VALUES ( 
[List of attributes as SQL insert params]) 


这 样 就 有 了 生成 CREATE 语句 的 模板 。 

有 了 这 个 模板 ， 我们 就 可 以 遍历 输入 源 提供 者 中 的 每 个 表 结 点 ， 
填 上 相应 的 值 。 在 我 们 的 例子 里 ，cur_table 就 是 每 张 表 的 名 称 ， 而 
List of attributes as input params 和 List of attributes_ 
as SQL insert params 则 是 从 字段 结 点 中 得 出 的 。 

用 伪 代 码 描述 的 话 ， 创 建生 成 代码 的 过 程 就 是 这 样 的 : 

(1) 为 希望 生成 的 代码 制作 一 个 样 例文 件 。 

(2) 抽 掉 定制 部 分 ， 换 成 变量 ， 这 样 就 得 到 了 模板 。 

(3) 编制 读 取 模板 的 代码 ， 遍 历 输入 源 ， 根 据 需 要 替换 模板 文件 
中 的 变量 

(4) 把 新 生成 的 文件 保存 到 磁盘 上 。 

(5) 最 后 对 文件 进行 某 种 操作 ( 运行 、 编 译 等 )。 


组 件 驱 动 式 设计 


有 一 条 经 验 是 把 所 有 的 生成 器 都 变 成 独立 的 库 。X20 在 早期 的 时 
候 就 是 一 个 有 一 大 堆 代 码 的 大 文件 。 生 成 数据 库 、SQL 脚本 、 数 据 访 
HJE, Web 服务 、Flash 对 象 和 CMS 文件 的 代码 全 都 堆 在 一 个 库 里 
面 。 虽然 这 也 能 工作 , 但 随 着 增长 它 变 得 没 法 管理 了 。 维 护 起 来 越 来 
越 难 , 因为 对 生成 器 的 任何 一 点 小 小 的 改动 都 意味 着 要 重新 编译 上 万 
行 代码 。 

后 来 我 们 把 各 个 部 分 拆 开 ,得 到 了 大 概 三 十 多 个 独立 的 库 。 这 下 
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维护 起 来 容易 多 了 。 我 们 还 有 一 个 统 揽 全 局 的 主 生成 器 库 , 通过 引用 
就 可 以 把 所 有 的 生成 器 连接 起 来 。 如 果 不 是 一 直 需 要 某 些 生成 噩 的 
话 ， 还 可 以 把 它们 关 掉 。 

不 管 怎么 说 , 封装 和 组 件 化 都 是 很 好 的 编程 习惯 。 但 如 果 我 们 要 
建立 好 几 二 个 小 的 生成 器 的 话 ， 这 两 点 就 格外 重要 了 。 

有 了 这 五 个 简单 的 小 窘 门 ， 我 们 就 可 以 开始 了 。 


自动 化 时 要 小 心 


那 代 码 生 成 有 什么 不 好 的 地 方 吗 ? 是 不 是 有 些 时 候 我 们 不 应 该 
用 呢 ? 是 的 。 下 面 就 是 你 在 自动 化 过 程 早 期 可 能 会 常 犯 的 错误 。 

避免 手动 调整 生成 的 代码 
制定 一 条 严格 的 规则 ,就 是 代码 在 生成 之 后 是 不 能 修改 的 。 生 成 
的 代码 就 像 精 美的 瓷器 一 样 : 你 打 碎 ， 你 赔钱 ! 

ARE MS REA TEA BBC, 那么 这 可 能 让 我 们 
的 流程 更 累 人 , 一 点 都 不 会 轻松 。 为 什么 呢 ? 比方 说 我 们 给 数据 库 加 
上 一 个 字段 , 希望 按照 更 新 后 的 数据 模型 重新 生成 代码 。 每 次 生成 的 
时 候 , 我 们 都 得 记 住 曾经 手动 修改 的 东西 ,还 要 保证 代码 会 原样 重新 
修改 一 遍 。 

如 果 生 成 的 代码 确实 需要 调整 ， 那 也 有 优雅 的 解决 方法 。 在 CH 
里 ,我 们 可 以 把 类 标 为 “部 分 类 ”( partial )， 这 样 我 们 就 可 以 在 多 个 
源 文件 里 定义 一 个 类 。 在 X20 里 ,每 个 生成 的 C# 类 都 是 部 分 类 ， 这 
样 就 算 有 需要 , 我 们 也 可 以 在 另外 的 文件 里 对 同一 个 部 分 类 添加 新 的 
方法 或 属性 。 

要 是 在 你 用 的 语言 里 没有 部 分 类 可 用 ， 也 仍然 有 其 他 优雅 的 手 
段 。 比 如 ， 你 可 以 扩展 (extend ) 类 或 是 编写 定制 的 辅助 类 (helper 


class )。 
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生成 的 代码 要 和 真正 的 代码 一 样 整洁 

手动 编程 的 时 候 ， 因 为 我 们 希望 以 后 维护 起 来 容易 ， 所 以 保持 代 
码 整洁 特别 重要 。 使 用 代码 生成 器 的 时 候 , 我 们 从 来 不 需要 去 实际 维 
护 生 成 的 代码 ， 只 会 维护 生成 器 , 结果 这 造成 我 们 没有 动力 让 生成 的 
代码 也 同样 整洁 。 

也 正 是 因为 这 个 原因 , 有 些 人 认为 代码 生成 是 在 快速 输出 和 定制 
代码 之 间 做 出 的 取舍 一 一 它 生成 了 许多 最 终 应 用 程序 很 少 会 用 到 的 
宛 余 代码 。 因 为 从 程序 里 冒 出 一 堆 堆 的 代码 太 容 易 了 ,所 以 我 们 可 能 
不 那么 在 意 它 生成 的 代码 是 不 是 简洁 、 优化。 但 这 个 问题 实际 上 很 好 
解决 。 

我 们 的 下 一 个 项 目 可 能 不 需要 某 一 套数 据 访问 方法 。 我 们 可 以 用 
输入 源 来 定义 一 些 选项 参数 , 这 样 就 不 会 生成 一 大 堆 项 目 不 需要 的 代 
码 。 随 着 生成 器 越 来 越 成 熟 , 我 们 可 能 会 关 掉 某 些 选 项 ,不 去 生成 某 
些 代码 。 这 也 是 组 件 式 设计 真正 起 作用 的 地 方 。 

有 些 人 说 代码 生成 器 生成 出 来 的 代码 不 够 优雅 , 但 这 和 代码 生成 
器 没什么 关系 ， 它 只 和 我 们 让 代码 生成 器 生产 什么 有 关 。 

如 果 生 成 的 类 里 有 重复 的 函数 或 公共 方法 , 我 们 可 以 重 构 代 码 生 
成 器 中 的 模板 ， 还 可 以 把 重复 的 函数 写成 独立 类 ， 放 在 生成 器 之 外 。 
我 们 还 可 以 把 手动 编程 中 的 技巧 应 用 到 生成 的 代码 里 。 

对 于 代码 生成 来 说 , 并 没有 什么 东西 阻止 我 们 遵循 好 的 编程 原则 。 

知道 不 要 生成 什么 

虽然 代码 生成 让 你 更 辩证 地 思索 日 常 工 作 中 的 模式 , 但 不 要 强加 
这 些 模式 也 是 很 重要 的 。 在 代码 生成 取得 了 儿 次 甜美 的 胜利 之 后 , 我 
们 可 能 会 觉得 所 向 披 靡 ,， 想 把 所 有 东西 都 放 到 代码 生成 器 里 面 ， 即 使 
是 那些 无 法 自动 化 (但 肯定 很 累 人 ) 的 东西 。 我 们 很 可 能 把 太 多 需要 
定制 的 东西 也 放 到 自动 化 的 机 器 里 了 。 
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这 时 我 们 就 需要 好 好 考虑 代码 生成 的 好 处 了 。 如 果 输 出 代码 需要 
太 多 的 定制 输入 , 或 用 起 来 需要 调整 的 地 方太 多 , 那么 也 许 我 们 一 开 
台 就 不 该 去 生成 这 部 分 代码 。 就 像 坏 代 码 有 一 股 不 好 的 “味道 ”一 样 ， 
不 好 的 代码 生成 也 有 一 股 难 闻 的 “味道 ”。 

写 代码 生成 器 可 以 让 我 们 仔细 考虑 什么 样 的 工作 繁琐 但 可 以 自 
动 化 ,什么 样 的 工作 仅仅 是 繁琐 而 已 。 
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ANS 


第 50 篇 自主 开发 的 情形 


代码 生成 和 对 象 关系 映射 锅 并 不 是 什么 新 鲜 玩 意 。 我 们 在 2006 
年 制作 自己 的 公司 框架 的 时 候 , 市 面 上 已 经 有 很 多 类 似 的 东西 , 我们 
也 可 以 直接 拿 来 用 。 当 然 , 要 是 这 样 的 话 , 开始 的 时 候 就 可 以 给 我 们 
省 下 无 数 的 时 间 了 。 从 零 开始 制作 任何 框架 都 是 一 项 让 人 望 而 生 芋 的 
工作 ， 特 别 是 我 们 知道 其 他 框架 已 经 开发 好 多 年 了 。 

于 是 , 在 如 今 这 个 拿 来 主义 的 文化 背景 下 ， 自然而然 地 就 会 产生 
疑问 : 如 果 已 经 有 了 可 能 毫 不 逊色 的 产品 , 为 什么 你 非 要 开发 自己 的 
框架 、 平 台 或 插件 呢 ? 

对 于 我 来 说 ， 有 三 大 原因 。 


深刻 理解 问题 空间 


写 自 己 的 工具 的 时 候 , 我 们 别 无 选择 , 必须 把 自己 完全 沉浸 在 这 
个 工具 极度 淘 望 解决 的 问题 里 。 我们 必须 成 为 这 个 领域 的 专家 。“ 咽 ， 
我 下 载 了 这 个 库 , 复制 了 这 段 范 例 程序 ， 改 了 改 参 数 ， 然 后 …… 我 也 
不 知道 ， 不 过 它 似 乎 就 跑 通 了 。” 这 种 事 是 行 不 通 的 。 没 有 多 少 事 比 
个 程序 员 只 知道 程序 能 工作 却 不 知道 为 什么 更 让 人 不 安 的 了 。 
比如 ， 很 多 对 象 关系 映射 (ORM ) 对 数据 都 是 默认 延迟 加 载 的 ， 
只 在 对 象 中 的 关系 数据 被 访问 的 时 候 ， 才 从 数据 库 里 读 取 这 个 数据 ， 
而 不 是 一 上 来 就 从 数据 库 里 读 和 人 关系 数据 。 这 一 点 特别 高 效 ,因为 杠 
架 只 有 在 我 们 请 求 数据 的 时 候 才 会 做 数据 库 查 询 。 在 任何 时 候 , 存储 
在 内 存 中 的 数据 都 会 相对 少 一 些 。 
对 于 新 手 ORM 用 户 来 说 ， 这 种 知识 只 是 可 有 可 无 而 已 。 他 可 能 
只 是 对 其 编程 ， 却 不 怎么 关心 这 个 概念 。 在 他 的 测试 环境 里 , 数据库 
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只 有 稀 稀 拉 拉 的 几 条 测试 记录 ， 他 写 的 利用 ORM 取 回 数据 的 代码 运 
行 得 漂 漂 亮 亮 。 就 这 么 成 了 。 

但 一 旦 他 把 代码 放 到 线 上 环境 中 ， 真 实 的 数据 开始 涌 和 的 时 候 ， 
他 写 的 这 段 看 起 来 无 害 的 调用 ORM 的 小 代码 一 下 子 就 让 服务 器 瘫痪 
了 。 比 如 ， 这 段 貌 似 无 率 的 代码 : 


foreach (Person person in myCompany.RelatedPeople) 


{ 
s.AppendLine(person.RelatedOffice.City) ; 


} 

是 在 对 公司 中 的 每 个 人 都 进行 一 次 数据 库 查 询 , 获得 他 们 的 办 公 
室 地 址 。 这 几 行 代码 就 可 能 意味 着 几 千 次 查询 。 

如 果 我 们 是 开发 工具 的 人 , 我 们 肯定 要 知道 所 有 可 能 捅 娄 子 的 地 
方 。 如 果 我 们 只 是 用 其 他 人 的 框架 ， 就 可 能 无 法 觉察 这 些 问 题 ， 等 发 
现 的 时 候 已 经 太 晚 了 。 


发 现 核心 问题 并 加 以 改进 


不 管 那些 汗 牛 充 栋 的 预制 工具 中 都 有 些 什 么 , 你 都 可 以 找到 某 个 
小 东西 加 以 改进 来 适应 你 编程 的 方式 一 一 更 好 地 适合 你 开发 的 软件 


就 我 自己 的 情况 而 言 , 理由 很 简单 。 没 有 一 个 框架 能 够 定制 生成 
直接 连接 数据 库 模 型 的 ActionScript 对 象 。 如 果 我 用 现成 的 东西 的 话 ， 
很 可 能 得 用 两 套 软件 : 一 套 来 建立 我 的 .NET 层 ， 另 一 套用 来 创建 
ActionScript 类 。 如 果 我 改动 了 数据 模型 ( 这 经 常 发 生 )， 我 就 得 分 别 
重建 软件 中 两 个 不 相干 的 部 件 。 

X20 在 很 多 方面 都 和 其 他 代码 生成 器 差不多 , 可 以 快速 生成 映射 
到 数据 库 模 式 的 对 象 , 但 它 是 专 为 我 们 业务 的 核心 需要 设计 的 ,没有 
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任何 一 种 工具 和 X20 生成 代码 的 方式 一 模 一 样 。 随 着 最 初 几 年 的 业 
务 增长 , 我 们 根据 开发 流程 来 量 喘 定做 软件 , 而 不 是 让 我 们 无 法 控制 
的 软件 决定 我 们 如 何 工 作 。 专 为 数据 库 驱 动 的 Flash 应 用 制作 一 个 代 
码 生 成 器 是 我 们 想 要 与 现 有 产品 进行 的 一 场 战 斗 。 这 是 一 个 我 们 想 要 
更 好 解决 的 问题 。 

Stack Overflow 的 开发 团队 也 走 过 了 同样 的 道路 ， 编 写 了 自己 的 
微型 ORM。 当 他 们 的 编程 论坛 网 站 最 初 发 布 的 时 候 ， 他 们 选择 了 
LINQ-2-SQL 来 处 理 所 有 的 数据 库 查询 。 但 随 着 流量 和 存储 数据 量 增 
长 到 一 定 程度 的 时 候 ， 性 能 损失 就 很 大 了 。 

鉴于 他 们 支持 的 流量 以 及 使 用 ORM 的 方式 ，LINQ-2-SQL 解释 
LINQ 查询 ,生成 相应 的 SQL 查询 ,然后 执行 查询 的 方式 实在 是 效率 
KIRT o 传统 ORM 上 查询 的 执行 速度 太 慢 了 。 

他 们 的 资深 工程 师 Sam Saffron 和 Marc Gravell 没 有 把 它 换 成 男 一 
个 现成 的 ORM, 而 是 开发 了 自己 的 轻 量 级 版 本 , 叫做 Dapper. Dapper 
的 执行 速度 要 快 得 多 , 因为 它 没有 LINQ-2-SQL 将 查询 转化 成 关系 对 
象 时 的 很 多 额外 开销 。 它 只 接受 原生 SQL 输入 ， 绕 过 了 将 一 种 特定 
域 语言 (如 LINQ ) 转换 成 男 一 种 ( 如 SQL ) 时 与 生 俱 来 的 一 些 瓶 颈 。 

不 过 ,你 虽然 提高 了 性 能 , 却 损 失 了 稳健 性 。Dapper 和 大 多 数 传 
统 ORM 不 同 ， 它 不 会 自动 将 查询 映射 成 对 象 的 关系 。 

在 Stack Overflow 的 代码 里 , 最 初 Dapper 只 是 在 有 性 能 瓶颈 的 地 
方 使 用 。 在 这 些 地 方 ， 损 失 一 些 对 传统 ORM 编程 时 的 优雅 来 换取 执 
行 速度 的 提升 是 值得 的 。 如 今 , 他 们 几乎 所 有 新 的 工作 都 是 用 Dapper 
完成 的 。 通 过 自主 开发 ，Saffron 和 Gravell 揭示 了 瓶颈 所 在 ， 并 且 更 
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ANS 


D 他 们 写 Dapper 的 原因 请 参见 : http://samsaffron.com/archive/2011/03/30/How+I+ 
learned+to+stop+worrying+and+write+my+own+ORM。 
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好 地 解决 了 自己 的 特殊 问题 。 


程序 员 的 傲 骨 


开发 自己 的 工具 集 来 完成 工作 是 对 我 们 劳动 的 最 高 奖赏 。 对 于 程 
序 员 来 说 , 有 什么 比 开发 出 能 够 让 未 来 的 编程 变 得 大 为 容易 的 工具 更 
有 成 就 感 的 呢 ? 开发 自己 的 东西 总 是 让 人 干劲 十 足 。 

开发 自己 的 工具 集 的 时 候 , 我 们 对 于 自己 工作 中 珍视 的 东西 有 了 
更 多 的 了 解 。 很 多 时 候 ， 这 些 工 具 就 是 决定 职业 生涯 的 东西 。 这 是 因 
为 它们 不 仅 可 能 会 帮 到 其 他 程序 员 ， 也 能 揭示 我 们 决意 改进 的 东西 ， 
还 让 我 们 坚定 的 立场 浮 出 水 面 。 

我 们 开发 的 工具 也 是 自己 的 。 它们 充满 了 我 们 自己 关于 某 些 事情 
应 当 如 何 完 成 的 独特 见解 。 没有 人 能 够 告诉 我 们 应 当 如 何 开 发 帮 我 们 
自己 做 事 的 工具 , 所 以 在 写 这 些小 工具 的 时 候 , 我 们 能 够 决定 什么 是 
重要 的 。 对 于 某 些 人 来 说 ,为 自己 开发 工具 ， 就 暂时 不 用 为 他 人 写 代 
码 了 。 这 就 是 我 们 作为 程序 员 的 自豪 感 内 炊 的 地 方 。 

自豪 感 ， 我 们 的 旅程 也 就 以 它 收尾 吧 。 
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有 一 天 ,我 在 《纽约 时 报 》 的 社论 版 上 看 到 一 篇 标题 为 “建筑 工 
作 的 治愈 力 ”( The Healing Power of Construction Work ) 的 文章 。" 文 
章 中 ,一 位 来 自 中 美洲 的 木匠 谈 到 ,他 雇用 的 建筑 工人 中 ,多 数 都 和 
他 一 样 ， 曾 经 触犯 过 法 律 。 他 最 好 的 一 些 工匠 吸毒 成 阁 ， 曾 犯 重罪 。 
里 面 其 至 还 有 个 假释 的 杀人 犯 。 

他 想 说 的 并 不 是 建筑 工作 会 吸引 暴力 的 人 , 相反 ,， 它 为 这 些 命 途 
多 镍 的 人 提供 了 一 个 “疗伤 ”的 场所 ， 让 他 们 可 以 逃避 过 往 。 

我 们 做 手工 工作 的 时 候 会 很 平静 , 利用 原料 制作 东西 的 时 候 ， 精 
神 也 会 很 专注 。 这 位 木匠 的 雇工 不 是 把 建筑 仅仅 当做 一 份 工作 , 而 且 
还 是 对 现实 的 一 种 逃避 ， 是 一 个 真正 把 事情 做 好 的 机 会 。 

建筑 工作 本 身 会 带 来 一 种 回报 : 创造 之 前 并 不 存在 的 东西 所 带 来 
的 满足 感 。 只 要 愿意 学 习 ， 努 力 工作 , 关心 产品 ， 建 筑 工 作 是 任何 身 
强 体 健 的 人 都 能 够 做 的 事情 。 在 这 里 可 以 获得 成 功 , 即使 是 那些 在 生 
活 的 其 他 方面 未 曾 体会 过 成 功 的 人 也 有 机 会 。 

这 篇 文章 让 我 深 感 触动 ， 因为 我 看 待 编程 的 方式 正 是 如 此 。 我 没 
有 犯 过 重罪 ， 也 不 认识 哪个 程序 员 是 在 逃犯 。 不 过 ， 我 知道 很 多 人 ， 


D 参见 http://www.nytimes.com/2010/08/22/jobs/22pre.html , 
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不 管 他 们 承认 不 承认 , ARTEL Sit A BP ES CREE. 编程 
给 你 带 来 了 从 无 到 有 的 创造 的 快乐 。 

我 认识 的 大 多 数 程序 员 甚 至 不 关心 开发 的 是 什么 或 是 为 谁 开发 。 
只 要 是 在 解决 一 个 有 趣 的 问题 ， 只 要 有 机 会 能 够 优雅 地 创造 一 些 东 
西 ， 他 们 就 感到 满意 。 将 一 个 问题 条 分 缕 析 ， 然 后 解决 得 巧夺天工 ， 
这 种 精神 鸦片 让 程序 员 不 能 自拔 。 

我 们 之 所 以 开发 和 设计 软件 ,是 因为 我 们 真 的 热爱 做 这 个 ,无 论 
这 种 感情 是 溢于言表 还 是 藏 在 内 心 深 处 。 我 认识 的 最 优秀 的 程序 员 会 
不 断 雕 琢 每 一 个 开发 决定 ， 有 时 甚至 是 无 关 紧要 的 开发 决定 。 正 如 那 
些 建 筑 工 人 一 样 ， 我 们 并 不 仅仅 是 写 代 码 ， 而 是 要 把 代码 写 好 。 

对 热爱 这 份 工作 的 人 来 说 ,工作 并 不 仅仅 是 为 了 挣 钱 。 更 容易 的 
挣 钱 方法 也 有 。 这 个 职业 完全 是 我 们 自己 的 选择 。 
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9.1 形象 是 个 问题 


问题 何在 ?我们 这 个 挺 小 的 圈子 之 外 的 人 , 很 少 能 够 认识 到 软件 
开发 能 够 带 来 多 少 回报 , 甚至 我 们 当中 很 多 人 也 没有 完全 认识 到 这 一 
点 。 这 也 就 是 我 自称 Web 软件 应 用 程序 员 时 浑身 不 舒服 的 原因 。 这 
种 说 法 里 面 透 着 那 种 随遇而安 的 世故 。 也 许 这 主要 是 我 们 工作 的 性 质 
决定 的 吧 。 

在 人 生 的 低谷 , 我们 情绪 低落 ， 满 面 愁 容 ,， 不 停 地 跳 构 。 我 们 的 
困境 和 其 他 行业 并 没有 什么 不 同 , 但 我 们 感到 耻辱 是 因为 此 时 和 我 们 
最 有 激情 时 的 状态 有 巨大 的 落差 。 

我 们 完全 投入 工作 的 时 候 ， 会 比 大 多 数 人 更 沉浸 在 自己 的 思绪 
里 。 双 手打 字 ， 双眼 紧 盯 着 屏幕 出 神 。 望 着 窗外 ， 若 有 所 思 ， 可 实际 
上 我 们 什么 都 没 看 见 ， 只 有 伪 代 码 在 头脑 中 运行 。 面 无 笑容 ,并 不 言 
语 ， 也 不 期 待 有 人 答 话 。 我 们 此 时 只 愿 独处 , 与 自己 的 思绪 独处 ,无 
论 世 事变 幻 , 这 就 是 富有 激情 的 程序 员 完 全 从 周围 的 世界 中 逃脱 出 来 
的 情景 。 

但 当 我 们 毫 无 生 趣 的 时 候 ， 我们 也 很 安静 。 面 无 笑容 ,不想 和 人 
说 话 。 唯 一 的 区 别 是 , 我 们 打字 时 有 气 无 力 ， 眼 望 窗外 时 注意 到 了 周 
围 的 世界 , 并 且 想 要 走出 门 去 。 如 果 有 人 鼓励 一 下 , 我 们 会 长 叹 一 声 ， 
播 击 桌面 ， 再 吐 喀 几 句 我 们 如 何不 满 于 手头 的 工作 。 闷 闽 不 乐 的 程 
序 员 可 能 和 心满意足 的 程序 员 看 起 来 差不多 ， 差 别 不 过 是 一 声 长 叹 
而 已 。 

所 以 , 我 们 有 了 形象 问题 。 世界 上 其 他 人 都 把 程序 员 看 成 一 帮 戴 
着 耳机 的 隐居 型 怪人 ， 可 我 们 实际 上 是 富有 激情 的 手艺 人 和 思想 者 。 
咋 会 这 样 了 呢 ? 
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9.2 ” 豪 饪 行业 的 一 课 


LETT ie EAT LIE. Emeril Lagasse, Bobby Flay, Mario Batali 
和 Gordon Ramsay 都 是 热情 洋溢 ( 有 时 候 甚至 有 点 烦人 ) 的 大 厨 ， 热 
情 简直 要 从 他 们 的 毛孔 中 冒 出 来 。 他 们 的 热情 不 仅 感 染 了 其 他 厨师 ， 
更 感染 了 大 众 。 我 们 (不 那么 出 名 ) 的 同辈 就 没有 这 种 国际 魅力 了 。 
程序 员 中 没有 什么 名 人 能 够 感染 程序 员 之 外 的 人 群 。 
乍 一 想 , 你 可 能 会 觉得 这 是 因为 相对 于 编程 来 说 ， 人 们 一 般 更 愿 
意 毫 饪 。 不 过 ,我 可 以 向 你 保证 ,虽然 我 每 次 在 大 厨 制 作 “ 碎 辣 根 三 
文 鱼 配 炯 蔬菜 和 土豆 泥 ” 时 都 会 垂 洗 三 尺 , 但 我 可 不 会 去 自己 做 这 道 
菜 。 毫 饪 行业 已 经 找到 了 一 种 将 手艺 推销 给 所 有 人 的 办 法 ， 即 使 我 们 
中 很 多 人 从 来 都 没有 摸 过 锅 。 

也 许 这 就 是 因为 我 们 爱 吃 嘛 。 食物 看 起 来 就 诱 人 。 观 党 某 人 豪 调 
的 过 程 激 起 了 我 们 最 原始 的 情感 。 有些 人 把 它 称 为 “食品 色情 ”( food 
porn )。 但 如 今 的 食品 热潮 并 不 是 由 来 已 入 ， 豪 饪 节目 毕竟 已 经 存在 
几 十 年 了 。 我 们 大 多 数 人 都 听 说 过 Julia Child, 但 你 听 说 过 Justin 
Wilson, Jeff Smith 或 Graham Kerr 四 ? 他 们 的 毫 调 节 上 日 也 上 映 多 年 ， 
但 当时 的 社会 对 毫 调 没有 这 么 大 的 热情 , 他 们 从 来 没有 像 如 今 的 同行 
那样 获得 的 广泛 认同 。 那 么 是 什么 东西 发 生变 化 了 呢 ? 

过 去 , 毫 饪 节目 看 起 来 就 像 在 奶奶 的 厨房 里 : 几 部 摄像 机 , 一 个 
老 学 究 在 那 念 妃 要 加 上 小 半 杯 这 个 , 一 茶匙 那个 。 就 饪 节目 是 给 那些 
BERERA, 它们 从 来 没有 影响 到 目标 观众 之 外 的 人 。 豪 饪 无 
非 是 豪 饪 。 如 今 ， 节 目的 切 人 点 可 是 完全 不 同 了 。 

首先 ， 它们 强调 细节 。 这 里 有 一 个 特写 , 然后 义 有 一 个 大 特写 一 一 你 
可 以 看 到 厚 厚 的 牛 里 脊 肉 上 的 花纹 ， 还 可 以 瞄 一 眼 主 厨 的 指甲 是 不 是 干 
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净 。 高 清 电视 帮助 了 食品 行业 ， 当 然 也 帮助 了 其 他 行业 来 进行 销售 。 过 
去 ， 牛排 就 是 牛排 。 如 今 ， 是 关于 肥瘦 相间 的 精美 花纹 、 流 消 的 肉汁 和 
烤 架 印 。 细 节 正 是 吸引 力 之 所 在 。 
其 次 ,如 今 的 节目 让 豪 饪 变 得 平易 近 人 。 电 视 豪 饪 节目 只 是 照 着 
菜谱 做 菜 的 日 子 已 经 过 去 了 ， 如 今 的 节目 强调 “简单 "。 每 个 人 都 能 
做 。 三 十 分 钟 做 好 一 顿 饭 ,五 美元 做 一 道 业 ,然后 就 可 以 和 朋友 们 享 
受 美好 时 光 了 。 豪 饪 变 得 简便 易 行 而 富有 乐趣 了 。 

大 厨 把 他 们 手中 的 食物 描绘 得 如 御用 珍 饼 一 样 。 他 们 对 于 原料 和 
口味 的 描述 都 充满 激情 ， 即 使 只 是 用 那些 平淡 无 奇 的 形容 词 : 新 鲜 、 
可 口 、 美 味 。 如 今 , 大 厨 总 是 最 先 品 尝 自 己 的 作品 (一 般 是 在 节目 的 
高 潮 结 尾 ), FASE EIKA “UBER ~~” A SHES MTA ES PT HAS BEI: o 

更 有 甚 者 ， 坏 的 东西 也 能 大 卖 。 找 个 礼拜 五 晚上 上， 到 一 个 真正 的 
餐厅 厨房 去 看 看 实情 吧 。 大 喊 大 叫 、 汗 如 雨 下、 食物 掉 在 地 上 ， 简 直 
是 危机 四 伏 。 在 Anthony Bourdain 的 《及 脏 的 点 滴 》( The Nasty Bits ) 
一 书 中 ,“ 系 统 D” 摘 绘 的 景象 和 电视 上 展现 的 一 侍 不 染 的 亮 饪 世界 
可 谓 大 相 径 庭 ， 这 本 书 可 是 跻身 《纽约 时 报 》 畅 销 书 排行 榜 的 哟 。 

在 电视 上 ，Gordon Ramsay 让 许多 濒临 倒闭 的 餐馆 中 的 情形 变 得 
RY WH. ES ) ( Kitchen Nightmares ) 节目 展现 的 是 餐馆 经 营 
得 糟糕 透顶 却 依然 营业 的 事实 。 看 着 一 家 餐馆 从 几乎 无 可 避免 的 灾难 
中 脱身 而 出 ,显然 这 挺 有 意思 的 。 训 饪 行业 已 经 学 会 向 大 众 推销 自己 
的 商品 了 。 

其 他 行业 的 领跑 者 也 已 经 找到 了 自己 的 灵丹妙药 。 他们 呈现 自己 
手艺 的 方式 能 够 触动 我 们 的 神经 ， 让 本 来 没有 什么 兴趣 的 人 也 开始 
关心 。 

不 同意 这 个 说 法 ?随便 哪 一 天 晚上 翻 翻 各 个 电视 频道 吧 。 过 去 几 
FE, 在 美国 和 欧洲 , 涌现 出 了 很 多 大 热 的 节目 : ARISEN («BC 
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命 捕捞 》 Deadliest Catch )、 训 犬 的 (《 狗 语 者 》，The Dog Whisperer )、 
少年 合唱 团 的 〈《 合 唱 团 》 The choir )、 减 肥 的 《超级 减肥 王 》 The 
Biggest Loser), WATA (CHERIE), Supernanny )、 蓝 领 脏 活 的 
(《 干 尽 苦 差 事 》, Dirty Jobs ) 以 及 抚养 八 胞 胎 的 (《 十 口 之 家 》, Jon and 
Kate Plus 8 )。 这 些 行业 本 来 都 算 不 上 特别 光鲜 的 。 


ANDERSON 


“一 个 姑娘 ， 一 个 魁梧 的 单身 汉 ， 还 有 七 个 小 矮人 ? ! 
你 确定 这 不 是 真人 秀 ? !” 


那 为 啥 软件 开发 就 不 行 呢 ? 我 们 为 什么 就 不 能 像 别 人 一 样 , 对 自 
己 的 行业 进行 营销 宣传 呢 ? 代码 可 以 让 我 们 玩 游 戏 , 交 朋 友 , 在 这 个 
世界 上 任何 一 个 角落 和 他 们 聊天 ， 找 到 真爱 ， 购 买 东 西 ， 监 控 病 人 ， 
打 理 生活 , 还 可 以 做 其 他 许 许 多 多 的 事情 。 我 们 每 天 都 在 创造 这 些 神 
奇 的 工具 , 我 们 要 讲 的 故事 引人入胜 。 只 要 问 问 那 边 那 个 一 言 不 发 的 
家 伙 就 行 了 。 
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我 并 不 是 在 建议 近期 开始 试制 《项 级 程序 员 》 或 是 《编码 梦 魔 》 
之 类 的 节目 , 但 我 们 应 当 让 自己 多 在 公众 面前 曝光 。 我们 生产 了 如 今 
社会 赖 以 运行 的 工具 , 我 们 中 的 一 些 人 每 天 都 在 努力 让 它们 变 得 比 过 
去 更 快 、 更 廉价 、 更 漂亮 。 编 程 是 一 项 让 人 着 迷 的 工作 ， 而 把 它 展现 
给 其 他 人 是 我 们 的 责任 。 

软件 世界 在 好 的 时 候 就 像 一 个 井井有条 的 厨房 , 坏 的 时 候 就 是 彻 
底 的 组 织 疆 梦 。 传 统 在 其 他 领域 通常 意味 着 宏伟 和 永恒 , 但 在 软件 行 
业 则 不 同 。 我 们 所 处 的 环境 也 在 不 断 变化 。 如 今 我 们 使 用 的 东西 在 五 
年 后 看 起 来 就 会 像 古董 一 样 。 这 些 都 是 可 以 讲 给 公众 的 话题 。 

做 这 件 事 需要 循序 渐进 。 第 一 步 就 是 我 们 每 个 人 对 待 工作 的 方 
式 。 在 餐馆 里 , 好 的 侍者 为 展现 一 道 菜 而 自 察 。 这 不 光 是 大 厨 的 一 道 
菜 , 也 是 侍者 的 一 道 菜 。 手艺 就 是 精美 的 佳肴 与 单纯 的 食料 之 间 的 区 
别 。 从 这 个 意义 上 讲 , 我 们 也 应 当 为 自己 的 工作 感到 自豪 。 我 们 应 当 
经 常 摘 下 耳机 , 尽 可 能 多 地 和 非 技 术 人 员 交 流 。 软 件 开发 也 有 很 多 故 
事 可 讲 。 

开发 软件 的 过 程 同 样 可 以 是 贷 有 趣味 、 引 人 人 入 胜 的 。 我 们 做 的 确 
实 是 一 个 可 以 营销 的 行业 。 这 要 靠 我 们 来 让 它 变 得 不 局 限于 代码 , 正 
如 豪 饪 行业 已 经 超出 了 配料 的 范畴 。 让 我 们 一 起 用 热情 把 它 散 播 给 其 


他 人 吧 。 

这 是 我 每 天 都 要 经 历 的 挣扎 。 每 当 别 人 问 起 我 是 做 什么 的 ,我 都 
BEJA. 

我 想 说 ， 我 是 一 个 Web 程序 员 和 设计 师 一 一 如 果 你 愿意 ， 可 以 


说 是 “一 个 现代 程序 员 ”。 但 “程序 员 ” 并 不 能 引起 我 想 要 的 那 种 反 
响 ， 它 缺乏 医生 、 建 筑 师 或 美国 总 统 的 那 种 气概 。“ 医 生 ” 意 味 着 创 
造 奇 迹 、 妙 手 回春 ,“ 建 筑 师 ”有 暗 指 梦想 家 和 建造 大 师 ， 我 听 说 当 美 
总 统 也 是 有 些 福利 的 。 
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对 外 行 来 说 ， 程 序 员 就 等 于 “ 搞 电 脑 ”， 这 也 不 比 把 外 科 手 术 等 
R 好 到 哪里 去 。 下 次 有 人 问 我 是 做 什么 的 , 我 
就 说 我 是 乡村 歌手 好 了 ， 起码 这 还 容易 点 儿 。 

事实 上 ， 有 时 候 我 们 是 集 医 生 、 建 筑 师 和 统治 者 于 一 身 。 我 们 用 
代码 创造 奇迹 ,让 梦想 驰 怠 ， 苦 心 建造 ， 然 后 指点 江山 。 他 们 要 是 问 
我 是 做 什么 的 ， 我 就 给 他 们 看 看 这 本 书 。 
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“这 是 Pragmatic Programmers 系 列 中 的 又 一 本 书 一 一 对 新 手 来 说 是 指引 ， 
对 专家 来 说 是 重 温 ， 这 是 关于 程序 员 技艺 ( 和 生活 ) 的 一 本 美妙 的 智慧 集 。” 
一 一 Derek Sivers, CD Baby 和 sivers.org 的 创始 人 


“Ka Wai Cheung 先 生 为 那些 寻找 自己 赖 以 生存 的 代码 的 专业 开发 人 员 写 了 
一 本 书 。 这 本 书 不 是 用 那些 在 任何 博客 中 都 能 找到 的 传统 想法 拼凑 起 来 的 ， 而 是 
用 强 有 力 且 有 针对 性 的 方法 ， 讲 述 专业 编程 的 技艺 和 现实 。 
如 果 你 想 找 一 本 新 瓶装 旧 酒 的 编程 规则 ， 那 就 不 用 看 这 本 书 了 。 但 是 ， 如 果 
你 正在 寻找 一 种 视角 ， 看 看 软件 开发 是 什么 ， 或 者 你 想 要 一 套 由 真实 经 验 提 炼 出 
的 指导 方针 ， 那 这 本 书 正 是 你 需要 的 。” 
一 一 Bob Walsh， 作 家 、47 Hats 的 创始 人 


“充满 “美味 ”的 经 验 ， 每 篇 的 大 小 也 十 分 “ ”一 一 在 这 本 书 里 你 可 以 
学 到 很 多 。 花 上 些 时 间 从 过 来 人 那里 学 学 吧 。” 


一 一 Adam Hoffman， 高 级 开发 主管 


“一 本 好 书 ， 有 现代 程序 员 从 日 新 月 异 的 世界 中 得 到 的 提示 、 技 巧 和 经 验 教 
训 。 从 事 开发 或 与 开发 人 员 合作 的 人 士 不 可 不 看 。” 


一 一 Caspar Dunant, Webfish 
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